**
魔术方法
**
__del__方法
class A():
num=0
def __init__(self,name):
A.num+=1#每定义一个对象我的计数器加1
self.name=name
def __del__(self): #在对象被销毁前调用
A.num-=1
print(self.name,"被删除,还剩{}个对象".format(A.num))
a=A("张三")
b=A("李四")
c=A("王五")
print(A.num)
del a #若没有下面三行代码程序也会自动调用上方的__del__方法
del b
del c
触发机制:当一个对象在内存中被销毁时自动执行
无返回值
作用:可在对象销毁的时候做一些操作
__repr__方法
class Person():
def __init__(self,name,age):
self.name=name
self.age=age
# def __str__(self):#若__str__在则先调用此方法
# return "叫{},年龄{}".format(self.name,self.age)
def __repr__(self):#若代码中没有__str__方法则调用此方法
return "姓名{},年龄{}".format(self.name,self.age)
person=Person("张三",19)
print(person)
__repr__是__str__的“备胎”,如果类中没有找到__str__则调用__repr__方法
可试打印上方代码试着将__str__方法注释掉,在执行得到结果。
__new__方法
class Stu():
#实例化的时候触发,实际是创建一个新的对象
def __new__(cls, *args, **kwargs):
print("11111111")
return object.__new__(cls)#用object类,去创建一个此类的对象实体cls,代表的是本类
def __init__(self,name,age):#初始化的时候触发
print("22222222")
self.name=name
self.age=age
zs=Stu("张三",19)
print(zs.name)
没事别碰这个方法,先触发__new__才会触发__init__方法
__hash__方法
a={"a","b",[1,2,3]}
print(a)#报错【1,2,3】是不可哈希的
另外,id是hash的16倍
class Stu():
def __init__(self,name):
self.name=name
def __eq__(self, other):
return self.name==other.name
# def __hash__(self): #__hash__方法会隐式设置成None
# return hash(self.name)
a=Stu("张三")
b=Stu("李四")
c=Stu("张三")
print(hex(id(a)))
print(hex(id(b)))
print(hex(id(c)))
print(a==b)
print(a==c)
d={a,b,c}
print(d)
若只定义了__eq__方法,没有定义__hash__方法,__hash__方法会隐式设置成
None