其他魔术方法:
__call__:如果需要把对象当作一个函数用的时候,重写__call__方法,就能通过实例对象直接调用
比如
class a():
def __call__(self,name):
print('------>',name)
aa=a()
aa('Dillon')
runfile('D:/daima/wecenter/test_case/untitled0.py', wdir='D:/daima/wecenter/test_case')
------> Dillon
__del__
引入__del__前先看一个例子:
import sys
class a():
def __init__(self,name):
self.name=name
def name(self,name):
print('------>',name)
p=a('Tom')
p1=p
p2=p
p1.name='Jack'
print(p.name)
print(sys.getrefcount(p))#获取指向这个地址的个数
runfile('D:/daima/wecenter/test_case/untitled0.py', wdir='D:/daima/wecenter/test_case')
Jack
4
p,p1,p2都指向的是一个地址,这个地址中的name,原先name=‘Tom',但是p1.name=‘Jack’,把这个地址中的name值改变了
这时候我要删除一个引用(指向这个地址的对象)del p
import sys
class a():
def __init__(self,name):
self.name=name
def name(self,name):
print('------>',name)
def __del__(self):
print('---del--->')
p=a('Tom')
p1=p
p2=p
p1.name='Jack'
print(p.name)
del p2
print(sys.getrefcount(p))#获取指向这个地址的个数
runfile('D:/daima/wecenter/test_case/untitled0.py', wdir='D:/daima/wecenter/test_case')
Jack
3
---del--->
1.当一块空间没有了任何引用,默认执行__del__
2.当执行完一段代码后,python解释器会回收这一次执行时开辟的空间,所以最后会如同1步骤,执行__del__
本文总结