本文实例讲述了Python引用计数操作。分享给大家供大家参考,具体如下:
为了简化内存管理,Python通过引用计数机制实现了自动的垃圾回收功能,Python中的每个对象都有一个引用计数,用来计数该对象在不同场所分别被引用了多少次。每当引用一次Python对象,相应的引用计数就增1,每当消毁一次Python对象,则相应的引用就减1,只有当引用计数为零时,才真正从内存中删除Python对象。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
import ctypes def get_ref(obj): """ returns a c_size_t, which is the refcount of obj """ return ctypes.c_size_t.from_address( id (obj)) l = [ 1 , 2 , 3 , 4 ] l2 = l l_ref = get_ref(l) print l_ref del l print l_ref del l2 print l_ref another_list = [ 0 , 0 , 7 ] a_ref = get_ref(another_list) print a_ref |
输出:
c_ulong(2L)
c_ulong(1L)
c_ulong(0L)
c_ulong(1L)
运行结果如下图所示:
另外python编译成字节码的模块为 dis
1
2
3
4
5
6
|
import dis # bytecode disassembler module def time_2(x): return 2 * x dis.dis(time_2) print "*" * 20 dis.dis(get_ref) |
结合上述代码,测试示例如下:
1
2
3
4
5
6
7
8
9
10
|
import ctypes import dis # bytecode disassembler module def get_ref(obj): """ returns a c_size_t, which is the refcount of obj """ return ctypes.c_size_t.from_address( id (obj)) def time_2(x): return 2 * x dis.dis(time_2) print "*" * 20 dis.dis(get_ref) |
运行结果:
7 0 LOAD_CONST 1 (2)
3 LOAD_FAST 0 (x)
6 BINARY_MULTIPLY
7 RETURN_VALUE
********************
5 0 LOAD_GLOBAL 0 (ctypes)
3 LOAD_ATTR 1 (c_size_t)
6 LOAD_ATTR 2 (from_address)
9 LOAD_GLOBAL 3 (id)
12 LOAD_FAST 0 (obj)
15 CALL_FUNCTION 1
18 CALL_FUNCTION 1
21 RETURN_VALUE
希望本文所述对大家Python程序设计有所帮助。
原文链接:https://blog.csdn.net/way88liu/article/details/41512243