python3中使用__slots__限定例項屬性操作分析
本文例項講述了python3中使用__slots__限定例項屬性操作。分享給大家供大家參考,具體如下:
正常情況下,當我們定義了一個class,建立了一個class的例項後,我們可以給該例項繫結任何屬性和方法,這就是動態語言的靈活性。先定義class:
# 類定義 class Person(object): pass
然後,嘗試給例項繫結一個屬性:
p = Person() p.name = "jadeshu" print(p.name)
輸出:
jadeshu
還可以嘗試給例項繫結一個方法:
# 類定義 class Person(object): pass p = Person() p.name = "jadeshu" print(p.name) def set_age(self,age): # 定義一個函式作為例項方法 self.age = age from types import MethodType p.set_age = MethodType(set_age,p) p.set_age(25) print(p.age)
輸出:
jadeshu
25
但是,給一個例項繫結的方法,對另一個例項是不起作用的:
p2 = Person() #建立新的例項 p2.set_age(25) #呼叫方法
出錯:
Traceback (most recent call last):
25
File "C:/Users/Administrator/Desktop/PycharmProjects/test.py",line 48,in <module>
p2.set_age(25)
AttributeError: 'Person' object has no attribute 'set_age'
為了給所有例項都繫結方法,可以給class繫結方法:
def set_score(self,score): self.score = score Person.set_score = set_score p.set_score(80) print(p.score)
輸出:80
給class繫結方法後,所有例項均可呼叫:
p.set_score(80) p2 = Person() p2.set_score(100) print(p.score) print(p2.score)
輸出:
80
100
通常情況下,上面的set_score方法可以直接定義在class中,但動態繫結允許我們在程式執行的過程中動態給class加上功能,這在靜態語言中很難實現。
使用__slots__
但是,如果我們想要限制例項的屬性怎麼辦?比如,只允許對Student例項新增name和age屬性。
為了達到限制的目的,Python允許在定義class的時候,定義一個特殊的__slots__變數,來限制該class例項能新增的屬性:
class Person(object): __slots__ = ('name','age') # 用tuple定義允許繫結的屬性名稱
然後,我們試試:
>>> s = Person() # 建立新的例項 >>> s.name = 'jadeshu' # 繫結屬性'name' >>> s.age = 25 # 繫結屬性'age' >>> s.score = 99 # 繫結屬性'score' Traceback (most recent call last): File "<stdin>",line 1,in <module> AttributeError: 'Student' object has no attribute 'score'
由於'score'沒有被放到__slots__中,所以不能繫結score屬性,試圖繫結score將得到AttributeError的錯誤。
使用__slots__要注意,__slots__定義的屬性僅對當前類例項起作用,對繼承的子類是不起作用的:
>>> class Student(Person): ... pass ... >>> s = Student() >>> s.score = 9999
除非在子類中也定義__slots__,這樣,子類例項允許定義的屬性就是自身的__slots__加上父類的__slots__。
更多關於Python相關內容感興趣的讀者可檢視本站專題:《Python面向物件程式設計入門與進階教程》、《Python資料結構與演算法教程》、《Python函式使用技巧總結》、《Python字串操作技巧彙總》、《Python編碼操作技巧總結》及《Python入門與進階經典教程》
希望本文所述對大家Python程式設計有所幫助。