python3中使用__slots__限定實(shí)例屬性操作分析
本文實(shí)例講述了python3中使用__slots__限定實(shí)例屬性操作。分享給大家供大家參考,具體如下:
正常情況下,當(dāng)我們定義了一個(gè)class,創(chuàng)建了一個(gè)class的實(shí)例后,我們可以給該實(shí)例綁定任何屬性和方法,這就是動(dòng)態(tài)語言的靈活性。先定義class:
# 類定義 class Person(object): pass
然后,嘗試給實(shí)例綁定一個(gè)屬性:
p = Person() p.name = "jadeshu" print(p.name)
輸出:
jadeshu
還可以嘗試給實(shí)例綁定一個(gè)方法:
# 類定義 class Person(object): pass p = Person() p.name = "jadeshu" print(p.name) def set_age(self, age): # 定義一個(gè)函數(shù)作為實(shí)例方法 self.age = age from types import MethodType p.set_age = MethodType(set_age, p) p.set_age(25) print(p.age)
輸出:
jadeshu
25
但是,給一個(gè)實(shí)例綁定的方法,對另一個(gè)實(shí)例是不起作用的:
p2 = Person() #創(chuàng)建新的實(shí)例 p2.set_age(25) #調(diào)用方法
出錯(cuò):
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'
為了給所有實(shí)例都綁定方法,可以給class綁定方法:
def set_score(self, score): self.score = score Person.set_score = set_score p.set_score(80) print(p.score)
輸出:80
給class綁定方法后,所有實(shí)例均可調(diào)用:
p.set_score(80) p2 = Person() p2.set_score(100) print(p.score) print(p2.score)
輸出:
80
100
通常情況下,上面的set_score方法可以直接定義在class中,但動(dòng)態(tài)綁定允許我們在程序運(yùn)行的過程中動(dòng)態(tài)給class加上功能,這在靜態(tài)語言中很難實(shí)現(xiàn)。
使用__slots__
但是,如果我們想要限制實(shí)例的屬性怎么辦?比如,只允許對Student實(shí)例添加name和age屬性。
為了達(dá)到限制的目的,Python允許在定義class的時(shí)候,定義一個(gè)特殊的__slots__變量,來限制該class實(shí)例能添加的屬性:
class Person(object): __slots__ = ('name', 'age') # 用tuple定義允許綁定的屬性名稱
然后,我們試試:
>>> s = Person() # 創(chuàng)建新的實(shí)例 >>> 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的錯(cuò)誤。
使用__slots__要注意,__slots__定義的屬性僅對當(dāng)前類實(shí)例起作用,對繼承的子類是不起作用的:
>>> class Student(Person): ... pass ... >>> s = Student() >>> s.score = 9999
除非在子類中也定義__slots__,這樣,子類實(shí)例允許定義的屬性就是自身的__slots__加上父類的__slots__。
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python面向?qū)ο蟪绦蛟O(shè)計(jì)入門與進(jìn)階教程》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python編碼操作技巧總結(jié)》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Python實(shí)現(xiàn)壓縮和解壓縮ZIP文件的方法分析
這篇文章主要介紹了Python實(shí)現(xiàn)壓縮和解壓縮ZIP文件的方法,結(jié)合具體實(shí)例形式分析了Python操作zip文件壓縮與解壓縮的常用操作技巧,需要的朋友可以參考下2017-09-09python統(tǒng)計(jì)文章中單詞出現(xiàn)次數(shù)實(shí)例
在本篇文章里小編給大家整理的是關(guān)于python統(tǒng)計(jì)文章中單詞出現(xiàn)次數(shù)實(shí)例,需要的朋友們參考學(xué)習(xí)下。2020-02-02matplotlib 對坐標(biāo)的控制,加圖例注釋的操作
這篇文章主要介紹了matplotlib 對坐標(biāo)的控制,加圖例注釋的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04OpenCV清除小面積連通域的實(shí)現(xiàn)方法
本文主要介紹了OpenCV清除小面積連通域的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09Python接口測試結(jié)果集實(shí)現(xiàn)封裝比較
這篇文章主要介紹了Python接口測試結(jié)果集比較封裝,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05python通過getopt模塊如何獲取執(zhí)行的命令參數(shù)詳解
這篇文章主要給大家介紹了關(guān)于python通過getopt模塊如何獲取執(zhí)行的命令參數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12