在 Python 中获取对象的引用计数
使用 sys.getrefcount()
方法获取对象的引用计数,例如 sys.getrefcount(obj1)
。 sys.getrefcount()
方法返回对象的引用计数。 该计数比预期高一,因为该方法创建了一个临时引用。
import sys
obj1 = {'id': 1, 'name': 'jiyik'}
print(sys.getrefcount(obj1)) # 👉️ 2
obj2 = obj1
print(sys.getrefcount(obj1)) # 👉️ 3
my_dict = {
'employee': obj1,
}
print(sys.getrefcount(obj1)) # 👉️ 4
sys.getrefcount()
方法返回所提供对象的引用计数。
计数比预期高一个,因为该方法创建了对所提供对象的临时引用。
import sys
obj1 = {'id': 1, 'name': 'jiyik'}
print(sys.getrefcount(obj1)) # 👉️ 2
如果需要获取直接引用给定对象的对象列表,可以使用 gc.get_referrers()
方法。
import sys
import gc
obj1 = {'id': 1, 'name': 'jiyik'}
print(sys.getrefcount(obj1)) # 👉️ 2
# [{'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x10d34a910>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': '/Users/jiyik/workspace/python/study/main.py', '__cached__': None, 'sys': <module 'sys' (built-in)>, 'gc': <module 'gc' (built-in)>, 'obj1': {'id': 1, 'name': 'jiyik'}}]
print(gc.get_referrers(obj1))
第一个对象是当前命名空间,第二个是我们声明的变量。
gc.get_referrers()
方法返回直接引用所提供对象的对象列表。
我们可以使用 id
函数或 is
运算符来检查两个变量是否引用同一个对象。
import sys
obj1 = {'id': 1, 'name': 'jiyik'}
print(sys.getrefcount(obj1)) # 👉️ 2
obj2 = obj1
print(sys.getrefcount(obj1)) # 👉️ 3
print(obj1 is obj2) # 👉️ True
print(id(obj1)) # 👉️ 139709435242240
print(id(obj2)) # 👉️ 139709435242240
print(id(obj1) == id(obj2)) # 👉️ True
obj1
和 obj2
变量指向内存中的相同位置并引用相同的对象。
id()
函数可用于获取对象的标识。
该函数返回一个整数,该整数保证在对象的生命周期内是唯一且不变的。
如果我使用 del
运算符删除 obj1
变量,我们仍然会通过 obj2
变量引用它。
import sys
obj1 = {'id': 1, 'name': 'jiyik'}
obj2 = obj1
print(sys.getrefcount(obj2)) # 👉️ 3
del obj1
print(sys.getrefcount(obj2)) # 👉️ 2
print(obj2) # 👉️ {'id': 1, 'name': 'jiyik'}
我们使用 del
运算符删除了 obj1
变量,因此 obj2
的引用计数减少到 2。
引用计数实际上是 1,但是 sys.getrefcount()
方法会创建对所提供对象的临时引用。
我们仍然可以通过 obj2 变量访问 obj1 的内容。
相关文章
Python pandas.pivot_table() 函数
发布时间:2024/04/24 浏览次数:82 分类:Python
-
Python Pandas pivot_table()函数通过对数据进行汇总,避免了数据的重复。
在 Python 中将 Pandas 系列的日期时间转换为字符串
发布时间:2024/04/24 浏览次数:894 分类:Python
-
了解如何在 Python 中将 Pandas 系列日期时间转换为字符串
在 Python Pandas 中使用 str.split 将字符串拆分为两个列表列
发布时间:2024/04/24 浏览次数:1124 分类:Python
-
本教程介绍如何使用 pandas str.split() 函数将字符串拆分为两个列表列。
在 Pandas 中将 Timedelta 转换为 Int
发布时间:2024/04/23 浏览次数:231 分类:Python
-
可以使用 Pandas 中的 dt 属性将 timedelta 转换为整数。
Python 中的 Pandas 插入方法
发布时间:2024/04/23 浏览次数:112 分类:Python
-
本教程介绍了如何在 Pandas DataFrame 中使用 insert 方法在 DataFrame 中插入一列。
使用 Python 将 Pandas DataFrame 保存为 HTML
发布时间:2024/04/21 浏览次数:106 分类:Python
-
本教程演示如何将 Pandas DataFrame 转换为 Python 中的 HTML 表格。
如何将 Python 字典转换为 Pandas DataFrame
发布时间:2024/04/20 浏览次数:73 分类:Python
-
本教程演示如何将 python 字典转换为 Pandas DataFrame,例如使用 Pandas DataFrame 构造函数或 from_dict 方法。
如何在 Pandas 中将 DataFrame 列转换为日期时间
发布时间:2024/04/20 浏览次数:101 分类:Python
-
本文介绍如何将 Pandas DataFrame 列转换为 Python 日期时间。