- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我想在python中检查int数据类型的大小:
import sys
sys.getsizeof(int)
结果是“436”,这对我来说没有意义。无论如何,我想知道我的机器将占用多少字节 (2,4,..?) int。
最佳答案
您得到的是 类 的大小,而不是类实例的大小。调用 int
获取实例的大小:
>>> sys.getsizeof(int())
24
如果这个尺寸看起来还是有点大,请记住 Python int
与(例如)c 中的 int
非常不同。在 Python 中,int
是一个成熟的对象。这意味着有额外的开销。
除了其他存储之外,每个 Python 对象都至少包含一个引用计数和对该对象类型的引用;在 64 位机器上,占用 16 个字节! int
内部结构(由标准 CPython 实现决定)也随着时间而改变,因此占用的额外存储量取决于您的版本。
int
对象的一些细节这是 Python 2 中的情况。(其中一些改编自 Laurent Luce 的博客文章)。整数对象表示为具有以下结构的内存块:
typedef struct {
PyObject_HEAD
long ob_ival;
} PyIntObject;
PyObject_HEAD
是定义引用计数和对象类型的存储的宏。 documentation 对此进行了详细描述。 ,代码可见this回答。
内存是按大块分配的,因此每个新整数都不会出现分配瓶颈。该 block 的结构如下所示:
struct _intblock {
struct _intblock *next;
PyIntObject objects[N_INTOBJECTS];
};
typedef struct _intblock PyIntBlock;
这些一开始都是空的。然后,每次创建一个新整数时,Python 使用 next
指向的内存并递增 next
以指向 block 中的下一个空闲整数对象。
我不完全确定一旦超过了普通整数的存储容量,这将如何变化,但是一旦你这样做了,int
的大小就会变大。在我的机器上,在 Python 2 中:
>>> sys.getsizeof(0)
24
>>> sys.getsizeof(1)
24
>>> sys.getsizeof(2 ** 62)
24
>>> sys.getsizeof(2 ** 63)
36
在 Python 3 中,我认为总体情况是一样的,但整数的大小以更零碎的方式增加:
>>> sys.getsizeof(0)
24
>>> sys.getsizeof(1)
28
>>> sys.getsizeof(2 ** 30 - 1)
28
>>> sys.getsizeof(2 ** 30)
32
>>> sys.getsizeof(2 ** 60 - 1)
32
>>> sys.getsizeof(2 ** 60)
36
当然,这些结果都取决于硬件! YMMV。
Python 3 中整数大小的可变性暗示它们的行为可能更像可变长度类型(如列表)。事实上,事实证明这是真的。这是 C struct
的定义对于 Python 3 中的 int
对象:
struct _longobject {
PyObject_VAR_HEAD
digit ob_digit[1];
};
comments伴随这个定义的总结了 Python 3 的整数表示。零不是由存储的值表示,而是由大小为零的对象表示(这就是为什么 sys.getsizeof(0)
是 24
字节,而 sys.getsizeof (1)
是 28
)。负数由具有负大小属性的对象表示!好诡异。
关于python - "sys.getsizeof(int)"返回一个不合理的大值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10365624/
我有以下二维位图: num = 521 arr = [i == '1' for i in bin(num)[2:].zfill(n*n)] board = [arr[n*i:n*i+n] for i
我一直在检查函数sys.getsizeof ,我知道这会返回正在传递的参数的大小(以字节为单位)。 我有一些使用 C 的经验,在知道某些类型的大小的情况下,我可以计算出某些值的大小。我已经用这个函数进
这个问题已经有答案了: "sys.getsizeof(int)" returns an unreasonably large value? (1 个回答) 已关闭 5 年前。 import sys p
我正在尝试创建一个大小为 1 MB 的列表。而以下代码有效: dummy = ['a' for i in xrange(0, 1024)] sys.getsizeof(dummy) Out[1]: 9
我在 Python 3.7 的 IDLE 中制作了两个列表,名称分别是 a 和 b它们在初始化方面会有所不同,但内容是相同的(正如我所想,但也许我错了) >>>a = [1,2,3,4] >>>a [
在使用 sys.getsizeof() 时,我注意到随着 ints 的大小增加,它会返回更高的值,这表明它们使用了更多的内存: >>> sys.getsizeof(3) 28 >>> >>> sys.
我刚刚运行了这些代码: v = [1,2,'kite',100**100] for x,y in enumerate(v): print ("{} size is: {}".format(y,
我正在尝试创建一个大小为 1 MB 的列表。而以下代码有效: dummy = ['a' for i in xrange(0, 1024)] sys.getsizeof(dummy) Out[1]: 9
这个问题在这里已经有了答案: How do I measure the memory usage of an object in python? (2 个回答) 关闭3年前。 我想计算一个对象使用的内
当我运行以下代码时,我分别得到3和36作为答案。 x ="abd" print len(x) print sys.getsizeof(x) 有人可以向我解释一下两者之间有什么区别吗? 最佳答案 在所有
我注意到当存储到 NumPy 数组时,nbytes 和 getsizeof 返回两个不同的值。 例子: import sys import numpy as np x = np.random.rand
我有一个大小为 10240 字节的文件。这是我获取文件大小的脚本: fh = open(name, "r") data = fh.read(10240) print sys.getsizeof(dat
为什么会这样?列表(有开销)不应该比字符串大吗? import sys print(sys.getsizeof('a'*1000)) # output is 1049 print(sys.getsiz
python 版本:Python 3.6.0b3(默认,2016 年 11 月 16 日,16:55:09) 我有以下输出: >>> sys.getsizeof([0 for x in range(1
我很好奇 - 为什么sys.getsizeof调用返回的列表数小于其元素之和? import sys lst = ["abcde", "fghij", "klmno", "pqrst", "uvwxy
为什么长度为1的python的sys.getsizeof()比长度为2的字符串的str大?(对于长度>2,该关系似乎如预期的单调增加)。 例子: >>> from string import asci
我很好奇 - 为什么 sys.getsizeof调用为列表返回一个小于其元素总和的数字? import sys lst = ["abcde", "fghij", "klmno", "pqrst", "
我想在python中检查int数据类型的大小: import sys sys.getsizeof(int) 结果是“436”,这对我来说没有意义。无论如何,我想知道我的机器将占用多少字节 (2,4,.
当我运行以下代码时,我分别得到 3 和 36 作为答案。 x ="abd" print len(x) print sys.getsizeof(x) 谁能给我解释一下它们之间有什么区别? 最佳答案 它们
我正在玩 python 列表,我想在不使用列表时从内存中删除它。(我有大数据列表,可能有数千或数百万个元素..数据类型-> 浮点型) 我试过这段代码,看看删除在 python 中是如何工作的(示例)
我是一名优秀的程序员,十分优秀!