python – 了解类变量的引用计数

前端之家收集整理的这篇文章主要介绍了python – 了解类变量的引用计数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

这是为了更好地理解引用计数在Python中的工作原理.

让我们创建一个类并实例化它.实例的引用计数为1(getrefcount显示2,因为它自己的内部结构引用该类实例将引用计数增加1):

>>> from sys import getrefcount as grc
>>> class A():
    def __init__(self):
        self.x = 100000


>>> a = A()
>>> grc(a)
2

a的内部变量x有2个引用:

>>> grc(a.x)
3

我希望它由a和_的__init__方法引用.然后我决定检查一下.

所以我在__main__命名空间中创建了一个临时变量b,以便能够访问变量x.它将ref-number增加1,使其变为3(如预期的那样):

>>> b = a.x
>>> grc(a.x)
4

然后我删除了类实例,引用计数减少了1:

>>> del a
>>> grc(b)
3

所以现在有2个引用:一个是b,一个是A(正如我所料).

通过从__main__命名空间中删除A,我希望计数再次减少1.

>>> del A
>>> grc(b)
3

但它不会发生.没有类A或其实例可以引用100000,但它仍然被__main__名称空间中的b以外的引用引用.

所以,我的问题是,除了b之外,100000引用了什么?

BrenBarn建议我应该使用object()而不是可以存储在内部某处的数字.

>>> class A():
    def __init__(self):
        self.x = object()


>>> a = A()
>>> b = a.x
>>> grc(a.x)
3
>>> del a
>>> grc(b)
2

删除实例a之后,b只有一个引用是非常合乎逻辑的.

唯一需要理解的是为什么数字100000不是这样的.

最佳答案
a.x是整数10000.此常量由对应于A的__init __()方法代码对象引用.代码对象始终包含对代码中所有文字常量的引用:

>>> def f(): return 10000
>>> f.__code__.co_consts
(None,10000)

这条线

del A

删除名称A并减少A的引用计数.在Python 3.x中(但不在2.x中),类通常包含一些循环引用,因此只有在显式运行垃圾收集器时才会收集垃圾.事实上,使用

import gc
gc.collect()

在del A之后确实导致b的引用计数减少.

猜你在找的Python相关文章