Python构造函数及解构函数介绍
python有一个相应的特殊解构器(destructor)方法名为__del__()。然而,由于python具有垃圾对象回收机制(靠引用计数),这个函数要直到该实例对象所有的引用都被清除掉后才会被执行。python中的解构器是在实例释放前提供特殊处理功能方法,它们通常没有被实现,因为实例很少被显式释放。
在下面的例子中,我们分别创建(并覆盖)__init__()和__del__()构造器及解构函数,然后,初始化类并给同样的对象很多别名。id()内建函数可用来确定引用同一对象的三个别名。最后一步是使用del语句清除所有的别名,显示何时调用了多少次解构器。
#!/usr/bin/envpython
#coding=utf-8
classP():
def__del__(self):
pass
classC(P):
def__init__(self):
print'initialized'
def__del__(self):
P.__del__(self)
print'deleted'
c1=C()
c2=c1
c3=c1
printid(c1),id(c2),id(c3)
delc1
delc2
delc3
python没有提供任何内部机制来跟跟踪一个类有多少个实例被创建了,或者记录这些实例是什么东西。如果需要这些功能,可以显式加入一些代码到类定义或者__init__()和__del__()中去。最好的方式是使用一个静态成员来记录实例的个数。靠保存它们的引用来跟踪实例对象是很危险的,因为你必须合理管理这些引用,不然你的引用可能没办法释放(因为还有其他的引用)!看下面的例子:
classInstCt(object):
count=0
def__init__(self):
InstCt.count+=1
def__del__(self):
InstCt.count-=1
defhowMany(self):
returnInstCt.count
a=InstCt()
b=InstCt()
printb.howMany()
printa.howMany()
delb
printa.howMany()
dela
printInstCt.count
所有输出:
initialized 437215010443721501044372150104 deleted ******************** 2 2 1 0
热门推荐
10 钢琴人祝福语女生简短
11 岗位考试顺利祝福语简短
12 关于老师蛋糕祝福语简短
13 娘家妈妈新婚祝福语简短
14 生日留言简短祝福语大全
15 祝福语诗意文案简短
16 校长退休文案祝福语简短
17 宝子生日祝福语简短
18 寒露祝福语毕业寄语简短