1. 程式人生 > 程式設計 >python3中使用__slots__限定例項屬性操作分析

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程式設計有所幫助。