################ 所有方法参考 __setattr__() ######################
类中:
__getattr__ () # 在调用不存在的属性时默认会调用
__setattr__() # 设置新的属性时会调用,就是通过此方法,将你设置的属性添加到了__dict__中。
如果类中定义了该方法,则设置属性时执行该方法,但是设置的属性没有添加到__dict__中
如果类中又定义了该方法,方法中也设置了属性,就会进入无限递归,
所以可以通过__dict__()来操作
例如:
# 一
class Foo(object):
def __init__(self, name, id):
self.name = name
self.id = id
def eat(self):
print("%s " % self.name)
def __setattr__(self, k, v):
print('hehheeeeeeeeeeeeeeeeee')
f1 = Foo('he', 12) # 设置属性,因为类中有了__setattr__,所以设置属性时会执行,
print(f1.__dict__) # 设置的属性并没有添加到__dict__中, 方法中并没有实现设置属性的功能
>>>
hehheeeeeeeeeeeeeeeeee
hehheeeeeeeeeeeeeeeeee
{}
# 二
class Foo(object):
def __init__(self, name, id):
self.name = name
self.id = id
def eat(self):
print("%s " % self.name)
def __setattr__(self, k, v):
print('hehheeeeeeeeeeeeeeeeee')
self.k = v # 再次处罚 __setattr__() 进入死递归
f1 = Foo('he', 12)
print(f1.__dict__)
>>>
RecursionError: maximum recursion depth exceeded # 死递归错误
# 三
class Foo(object):
def __init__(self, name, id):
self.name = name
self.id = id
def eat(self):
print("%s " % self.name)
def __setattr__(self, k, v):
print('hehheeeeeeeeeeeeeeeeee')
self.__dict__[k] = v # 只能通过此方式设置,底层也是这么做的,设置属性的本质
f1 = Foo('he', 12)
print(f1.__dict__)
>>>
hehheeeeeeeeeeeeeeeeee
hehheeeeeeeeeeeeeeeeee
{'name': 'he', 'id': 12}
# 其他方法类似
__delattr__ () # 删除属性时,会调用
__getattrbute__() #