浅谈Python 对象内存占用


Posted in Python onJuly 15, 2016

一切皆是对象

在 Python 一切皆是对象,包括所有类型的常量与变量,整型,布尔型,甚至函数。 参见stackoverflow上的一个问题 Is everything an object in python like ruby

代码中即可以验证:

# everythin in python is object def fuction(): return print isinstance(True, object) print isinstance(0, object) print isinstance('a', object) print isinstance(fuction, object)

如何计算

Python 在 sys 模块中提供函数 getsizeof 来计算 Python 对象的大小。

sys.getsizeof(object[, default])

以字节(byte)为单位返回对象大小。 这个对象可以是任何类型的对象。 所以内置对象都能返回正确的结果 但不保证对第三方扩展有效,因为和具体实现相关。

......

getsizeof() 调用对象的 __sizeof__ 方法, 如果对象由垃圾收集器管理, 则会加上额外的垃圾收集器开销。

当然,对象内存占用与 Python 版本以及操作系统版本关系密切, 本文的代码和测试结果都是基于 windows7 32位操作系统。

import sys print sys.version

2.7.2 (default, Jun 24 2011, 12:21:10) [MSC v.1500 32 bit (Intel)]

基本类型

•布尔型

print 'size of True: %d' % (sys.getsizeof(True)) print 'size of False: %d' % (sys.getsizeof(False))

输出:

size of True: 12 size of False: 12

•整型

# normal integer print 'size of integer: %d' % (sys.getsizeof(1)) # long print 'size of long integer: %d' % (sys.getsizeof(1L)) print 'size of big long integer: %d' % (sys.getsizeof(100000L)) 输出:

size of integer: 12x size of long integer 1L: 14 size of long integer 100000L: 16

可以看出整型占用12字节,长整型最少占用14字节,且占用空间会随着位数的增多而变大。 在2.x版本,如果整型类型的值超出sys.maxint,则自动会扩展为长整型。而 Python 3.0 之后,整型和长整型统一为一种类型。

•浮点型

print 'size of float: %d' % (sys.getsizeof(1.0))

输出:

size of float: 16

浮点型占用16个字节。超过一定精度后会四舍五入。

参考如下代码:

print 1.00000000003 print 1.000000000005

输出:

1.00000000003 1.00000000001

•字符串

# size of string type print '\r\n'.join(["size of string with %d chars: %d" % (len(elem), sys.getsizeof(elem)) for elem in ["", "a", "ab"]]) # size of unicode string print '\r\n'.join(["size of unicode string with %d chars: %d" % (len(elem), sys.getsizeof(elem)) for elem in [u"", u"a", u"ab"]])

输出:

size of string with 0 chars: 21 size of string with 1 chars: 22 size of string with 2 chars: 23 size of unicode string with 0 chars: 26 size of unicode string with 1 chars: 28 size of unicode string with 2 chars: 30

普通空字符串占21个字节,每增加一个字符,多占用1个字节。Unicode字符串最少占用26个字节,每增加一个字符,多占用2个字节。

集合类型

•列表

# size of list type print '\r\n'.join(["size of list with %d elements: %d" % (len(elem), sys.getsizeof(elem)) for elem in [[], [0], [0,2], [0,1,2]]])

输出:

size of list with 0 elements: 36 size of list with 1 elements: 40 size of list with 2 elements: 44 size of list with 3 elements: 48

可见列表最少占用36个字节,每增加一个元素,增加4个字节。但要注意,sys.getsizeof 函数并不计算容器类型的元素大小。比如:

print 'size of list with 3 integers %d' % (sys.getsizeof([0,1,2])) print 'size of list with 3 strings %d' % (sys.getsizeof(['0','1','2']))

输出:

size of list with 3 integers 48 size of list with 3 strings 48

容器中保存的应该是对元素的引用。如果要准确计算容器,可以参考recursive sizeof recipe 。使用其给出的 total_size 函数:

print 'total size of list with 3 integers %d' % (total_size([0,1,2])) print 'total size of list with 3 strings %d' % (total_size(['0','1','2']))

输出为:

total size of list with 3 integers 84 total size of list with 3 strings 114

可以看出列表的空间占用为 基本空间 36 + (对象引用 4 + 对象大小) * 元素个数。

另外还需注意如果声明一个列表变量,则其会预先分配一些空间,以便添加元素时增加效率:

li = [] for i in range(0, 101): print 'list with %d integers size: %d, total_size: %d' % (i, getsizeof(li), total_size(li)) li.append(i)

•元组

基本与列表类似,但其最少占用为28个字节。

•字典

字典的情况相对复杂很多,具体当然要参考代码 dictobject.c, 另外 NOTES ON OPTIMIZING DICTIONARIES 非常值得仔细阅读。

基本情况可以参考[stackoverflow] 的问题 Python's underlying hash data structure for dictionaries 中的一些回答:

•字典最小拥有8个条目的空间(PyDict_MINSIZE);
•条目数小于50,000时,每次增长4倍;
•条目数大于50,000时,每次增长2倍;
•键的hash值缓存在字典中,字典调整大小后不会重新计算;

每接近2/3时,字典会调整大小。

以上这篇浅谈Python 对象内存占用就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
用Python代码来绘制彭罗斯点阵的教程
Apr 03 Python
Python函数可变参数定义及其参数传递方式实例详解
May 25 Python
Python实现字典的key和values的交换
Aug 04 Python
Python实现七彩蟒蛇绘制实例代码
Jan 16 Python
python3 破解 geetest(极验)的滑块验证码功能
Feb 24 Python
python实现图片文件批量重命名
Mar 23 Python
Python pandas.DataFrame调整列顺序及修改index名的方法
Jun 21 Python
Python PyCharm如何进行断点调试
Jul 05 Python
python多任务之协程的使用详解
Aug 26 Python
Win10下python 2.7与python 3.7双环境安装教程图解
Oct 12 Python
python实现三次密码验证的示例
Apr 29 Python
Requests什么的通通爬不了的Python超强反爬虫方案!
May 20 Python
python发送邮件功能实现代码
Jul 15 #Python
Python中列表和元组的使用方法和区别详解
Dec 30 #Python
Python中的变量和作用域详解
Jul 13 #Python
在Python中通过threading模块定义和调用线程的方法
Jul 12 #Python
举例讲解Python编程中对线程锁的使用
Jul 12 #Python
使用Python编写一个最基础的代码解释器的要点解析
Jul 12 #Python
Python中使用bidict模块双向字典结构的奇技淫巧
Jul 12 #Python
You might like
PHP判断图片格式的七种方法小结
2013/06/03 PHP
PHP面向对象程序设计子类扩展父类(子类重新载入父类)操作详解
2019/06/14 PHP
Javascript里使用Dom操作Xml
2006/09/20 Javascript
JScript中使用ADODB.Stream判断文件编码的代码
2008/06/09 Javascript
JQuery toggle使用分析
2009/11/16 Javascript
关于js内存泄露的一个好例子
2013/12/09 Javascript
Javascript 学习笔记之 对象篇(二) : 原型对象
2014/06/24 Javascript
Javascript学习笔记之函数篇(五) : 构造函数
2014/11/23 Javascript
JavaScript内存管理介绍
2015/03/13 Javascript
纯js实现瀑布流布局及ajax动态新增数据
2016/04/07 Javascript
jquery html5 视频播放控制代码
2016/11/06 Javascript
详解如何使用webpack打包Vue工程
2017/05/27 Javascript
jQuery插件artDialog.js使用与关闭方法示例
2017/10/09 jQuery
JS实现点击链接切换显示隐藏内容的方法
2017/10/19 Javascript
微信小程序录音与播放录音功能
2017/12/25 Javascript
微信小程序表单弹窗实例
2018/07/19 Javascript
一步一步的了解webpack4的splitChunk插件(小结)
2018/09/17 Javascript
微信小程序顶部导航栏滑动tab效果
2019/01/28 Javascript
Linux下为不同版本python安装第三方库
2016/08/31 Python
解决Python 中英文混输格式对齐的问题
2018/07/16 Python
Python双向循环链表实现方法分析
2018/07/30 Python
Windows下将Python文件打包成.EXE可执行文件的方法
2018/08/03 Python
pandas 根据列的值选取所有行的示例
2018/11/07 Python
wxPython电子表格功能wx.grid实例教程
2019/11/19 Python
python双端队列原理、实现与使用方法分析
2019/11/27 Python
python之pymysql模块简单应用示例代码
2019/12/16 Python
使用python实现学生信息管理系统
2021/02/25 Python
CSS3 2D模拟实现摩天轮旋转效果
2016/11/16 HTML / CSS
屈臣氏马来西亚官网:Watsons马来西亚
2019/06/15 全球购物
DIY手工制作经营店创业计划书
2014/02/01 职场文书
承诺书模板
2014/08/30 职场文书
2014年财务工作总结范文
2014/11/11 职场文书
2015年专项整治工作总结
2015/04/03 职场文书
新员工辞职信范文
2015/05/12 职场文书
实践论读书笔记
2015/06/29 职场文书
2015教师个人师德工作总结
2015/10/23 职场文书