文章目录
Python的垃圾回收
在Python万物皆对象
,那么当程序中出现没有被引用的对象时就是垃圾,过多的垃圾会影响程序的运行效率,性能等;
Python具有自动的垃圾回收的机制,它会自动将这些没有被引用的对象删除,即不用手动的处理垃圾
垃圾回收
例1:
class A:
def __init__(self):
self.name = 'A类'
a = A()
print(a.name)
input('回车键退出...')
输出结果
A类
回车键退出...
***Repl Closed***
很明显,在终端输入回车键前A()
并不是垃圾,因为有一个变量a指向了这个在内存中存在地址的对象A()
,如下图
例2:
class A:
def __init__(self):
self.name = 'A类'
a = A()
print(a.name)
a = None # 将a设置为了None,此时没有任何的变量对A()对象进行引用,它就是变成了垃圾
input('回车键退出...')
输出结果
A类
回车键退出...
***Repl Closed***
当变量a指向None后,A()就变成了一个在内存中没有变量指向的内存,即没有被引用的对象,此时就是一个垃圾,如下图
__del__
特殊方法
为了看出变量是何时被删除的,使用__del__
特殊方法
例3:
class A:
def __init__(self):
self.name = 'A类'
# del是一个特殊方法,它会在对象被垃圾回收前调用
def __del__(self):
print('A()对象被删除了~~~',self)
a = A()
print(a.name)
a = None # 将a设置为了None,此时没有任何的变量对A()对象进行引用,它就是变成了垃圾
input('回车键退出...')
输出结果
A类
A()对象被删除了~~~ <__main__.A object at 0x0000022826233940>
回车键退出...
***Repl Closed***
可以看出,当a = None
后,就会执行__del__
特殊方法
例4:
class A:
def __init__(self):
self.name = 'A类'
# del是一个特殊方法,它会在对象被垃圾回收前调用
def __del__(self):
print('A()对象被删除了~~~',self)
a = A()
b = a # 又使用一个变量b,来引用a对应的对象
print(a.name)
a = None # 将a设置为了None,此时没有任何的变量对A()对象进行引用,它就是变成了垃圾
input('回车键退出...')
输出结果
A类
回车键退出...
A()对象被删除了~~~ <__main__.A object at 0x000001DEFFFB3E10>
***Repl Closed***
执行回车前没有调用__del__
特殊方法是因为,b变量指向了A(),即这个对象被引用了,并不是垃圾;执行回车后,Python自动执行垃圾回收机制,调用__del__
特殊方法
例5:
在程序执行结束前,手动的将引用断开,即调用__del__
特殊方法
class A:
def __init__(self):
self.name = 'A类'
# del是一个特殊方法,它会在对象被垃圾回收前调用
def __del__(self):
print('A()对象被删除了~~~',self)
a = A()
b = a # 又使用一个变量b,来引用a对应的对象
print(a.name)
a = None # 将a设置为了None,此时没有任何的变量对A()对象进行引用,它就是变成了垃圾
b = None
# del a
# del b
input('回车键退出...')
执行结果
A类
A()对象被删除了~~~ <__main__.A object at 0x0000018187963E10>
回车键退出...
***Repl Closed***
例6:
也可以直接删除变量,这样就会使A()称为一个没有被引用的对象
class A:
def __init__(self):
self.name = 'A类'
# del是一个特殊方法,它会在对象被垃圾回收前调用
def __del__(self):
print('A()对象被删除了~~~',self)
a = A()
print(a.name)
del a
input('回车键退出...')
执行结果
A类
A()对象被删除了~~~ <__main__.A object at 0x000001FE30C93940>
回车键退出...
***Repl Closed***