1、实例属性和类属性
千万不要把实例属性和类属性使用相同的名字,因为相同名称的实例属性将屏蔽掉类属性。
class Student(object):
name = 'Student'
# 创建实例 s
s = Student()
# 打印 name 属性,因为实例并没有 name 属性,所以会继续查找 class 的 name 属性
print(s.name)
# 打印类的 name 属性
print(Student.name)
# 给实例绑定 name 属性
s.name = 'Michael'
# 由于实例属性优先级比类属性高,因此,它会屏蔽掉类的name 属性
print(s.name)
# 但是类属性并未消失,用 Student.name 仍然可以访问
print(Student.name)
# 如果删除实例的 name 属性
del s.name
# 再次调用 s.name
print(s.name)
2、使用__slots__
# 先定义 class:
class Student(object):
pass
#给实例绑定一个属性
s = Student()
# 动态给实例绑定一个属性
s.name = 'Michael'
print(s.name)
# 给实例绑定一个方法
# 定义一个函数作为实例方法
def set_age(self, age):
self.age = age
from types import MethodType
# 给实例绑定一个方法
s.set_age = MethodType(set_age, s)
# 调用实例方法
s.set_age(25)
print(s.age) # 测试结果
# 给一个实例绑定的方法,对另一个实例是不起作用的
s2 = Student() # 创建新的实例
# 给 class 绑定方法后,所有实例均可调用
def set_score(self, score):
self.score = score
Student.set_score = MethodType(set_score, Student)
s.set_score(100)
print(s.score)
s2.set_score(99)
print(s2.score)
# 定义一个特殊的 __slots__ 变量,来限制该 class 实例能添加的属性
class Student(object):
__slots__ = ('name', 'age') # 用 tuple 定义允许绑定的属性名称
s = Student() # 创建新的实例
s.name = 'Michael' # 绑定属性'name'
s.age = 25 # 绑定属性'age'
s.score = 99 # 绑定属性'score'(不能绑定 score 属性)
# __slots__ 定义的属性仅对当前类实例起作用