__ slots__ 只能限制为实例对象动态添加属性和方法,而无法限制动态地为类添加属性和方法。
class Slots: __slots__ = ("name", "info") def test(self): print("This is Test") def info(self, name): print("正在调用实例方法", self.name) slots = Slots() slots.test() slots.name = 'Jim' print(slots.name) slots.info = info slots.info(slots, "Tom") slots.age = 15 print(slots.age)
运行结果:
This is Test Jim 正在调用实例方法 Jim Traceback (most recent call last): File "tests.py", line 101, in <module> slots.age = 15 AttributeError: 'Slots' object has no attribute 'age'
另外,__ slots__ 属性限制的对象是类的实例对象,而不是类,因此下面的代码是合法的:
Slots.age = 15 print(Slots.age) 运行结果: 15
此外,__ slots__ 属性对由该类派生出来的子类,是不起作用的。例如如下代码:
class CLanguage: __slots__ = ('name','add','info') #Clanguage 的空子类 class CLangs(CLanguage): pass #定义的实例方法 def info(self): print("正在调用实例方法") clang = CLangs() #为子类对象动态添加 say() 方法 clang.say = info clang.say(clang) ### 运行结果: 正在调用实例方法
所以,__ slots__ 属性只对当前所在的类起限制作用。
此外,如果子类也要限制外界为其实例对象动态地添加属性和方法,必须在子类中设置 __ slots__ 属性。那么子类实例对象允许动态添加的属性和方法,是子类中 __ slots__ 属性和父类 __ slots__ 属性的和。