您好,登錄后才能下訂單哦!
本文實例講述了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加上功能,這在靜態語言中很難實現。
但是,如果我們想要限制實例的屬性怎么辦?比如,只允許對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程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。