python - Python 'buffer' 类型有什么用?

Python中有一个buffer类型,但是我该如何使用呢?

在 Python documentation about buffer() ,说明是:

buffer(object[, offset[, size]])

object 参数必须是支持缓冲区调用接口(interface)的对象(如字符串、数组和缓冲区)。将创建一个引用 object 参数的新缓冲区对象。缓冲区对象将是从对象开头(或从指定偏移量)开始的切片。切片将延伸到对象的末尾(或具有由 size 参数指定的长度)。

最佳答案

示例用法:

>>> s = 'Hello world'
>>> t = buffer(s, 6, 5)
>>> t
<read-only buffer for 0x10064a4b0, size 5, offset 6 at 0x100634ab0>
>>> print t
world

在这种情况下,缓冲区是一个子字符串,从位置 6 开始,长度为 5,它不占用额外的存储空间 - 它引用字符串的一部分。

这对于像这样的短字符串不是很有用,但在使用大量数据时可能是必要的。此示例使用可变的 bytearray:

>>> s = bytearray(1000000)   # a million zeroed bytes
>>> t = buffer(s, 1)         # slice cuts off the first byte
>>> s[1] = 5                 # set the second element in s
>>> t[0]                     # which is now also the first element in t!
'\x05'

如果您想对数据拥有多个 View 并且不想(或不能)在内存中保存多个副本,这将非常有用。

请注意 buffer已替换为更好的名称 memoryview在 Python 3 中,尽管您可以在 Python 2.7 中使用。

另请注意,如果不深入研究 C API,您将无法为自己的对象实现缓冲区接口(interface),也就是说,您无法在纯 Python 中实现。

关于python - Python 'buffer' 类型有什么用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3422685/

相关文章:

c - 如何在 Linux 上递归列出 C 中的目录?

linux - cut 或 awk 命令打印第一行的第一个字段

linux - 如何将编译器的所有输出捕获到文件中?

linux - SO_REUSEADDR(setsockopt 选项)的含义是什么 - Linux?

python - 将 MATLAB 代码转换为 Python 的工具

mysql - 通过 shell 脚本使用 echo 命令自动化 mysql_secure_inst

python - 如何在 Python 中创建命名空间包?

python - 在 ipython 笔记本中测量单元执行时间的简单方法

linux - 在 Linux 的文本文件中用逗号替换空格

python - python的Maven等价物