我想创建一个小的NumPy整数来节省内存.但是,我注意到了
import numpy,sys
print sys.getsizeof(numpy.int8(1))
打印12,所以似乎numpy.int8()生成12个字节而不是1个字节的数据.为什么是这样?
最佳答案
Numpy标量具有与CPython数据类型类似的实现,例如python float或整数类型.换句话说,它是一个包含三个变量的结构:
原文链接:https://www.f2er.com/python/439283.html>类型为int的reference counter
>指向其对象类型实例的指针
>变量的值
在32位体系结构中,引用计数器和指针通常分别为4个字节.值字段原则上可以是任何大小,但是structure padding将导致struct分配4个字节,即使值需要更少.
如果您正在使用64位体系结构,请将“4字节”替换为“8字节”.
因此,32位系统上的所有numpy整数由(有效)三个4字节变量组成,而sys.getsizeof(numpy.int8(1))给出12.在64位系统上,它将返回24.
大多数numpy标量大小相同.一个例外是numpy.complex类型,通常需要双重存储.由于这在内存中与其他两个变量对齐,因此可以忽略填充并简单地将为该值分配的字节加倍,分别在32位和64位中分别给出16和32个字节.类似的规则适用于更奇特的类型(complex256,float80等)