本文实例讲述了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