问题:什么是Python缓冲区类型?
buffer
python中有一个类型,但是我不知道如何使用它。
在Python文档中,描述为:
buffer(object[, offset[, size]])
object参数必须是支持缓冲区调用接口的对象(例如字符串,数组和缓冲区)。将创建一个引用该对象参数的新缓冲区对象。缓冲区对象将从对象的开头(或指定的偏移量)开始是一个切片。切片将延伸到对象的末尾(或具有由size参数指定的长度)。
回答 0
用法示例:
>>> 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'
如果您想对数据有多个视图并且不想(或不能)在内存中保存多个副本,这将非常有用。
请注意,尽管您可以在Python 2.7中使用它,但是buffer
已经被memoryview
Python 3中的更好名称所代替。
还要注意,如果不深入研究C API,就不能为自己的对象实现缓冲区接口,即,不能在纯Python中做到这一点。
回答 1
我认为在将python与本机库接口时,缓冲区非常有用。(Guido van Rossum buffer
在此邮件列表帖子中进行了解释)。
例如,numpy似乎使用缓冲区进行有效的数据存储:
import numpy
a = numpy.ndarray(1000000)
的a.data
是:
<read-write buffer for 0x1d7b410, size 8000000, offset 0 at 0x1e353b0>