可以看到,屬性可以分為類屬性和實例屬性,那么問題就來了,如果類屬性和實例屬性名字相同時,會怎么樣,這就涉及Python中類屬性和實例屬性的優先級的問題了。
我們可以做一個實驗,在前面類定義的基礎上,在實例屬性中,也初始化一個localtion的屬性。
?class Animal(object): localtion = 'Asia' def __init__(self, name, age, localtion): self.name = name self.age = age self.localtion = localtion
接著我們初始化兩個實例,并把localtion打印出來。
?dog = Animal('wangwang', 1, 'GuangDong') cat = Animal('mimi', 3, 'ChongQing') print(dog.localtion) # ==> GuangDong print(cat.localtion) # ==> ChongQing print(Animal.localtion) # ==> Asia
可見,在類屬性和實例屬性同時存在的情況下,實例屬性的優先級是要高于類屬性的,在操作實例的時候,優先是操作實例的屬性。
另外,當實例沒有和類同名的時候,通過實例對象,依然可以訪問到類屬性。
class Animal(object): localtion = 'Asia' def __init__(self, name, age): self.name = name self.age = age cat = Animal('mimi', 3) print(cat.localtion) # ==> Asia
那通過實例,可不可以修改類屬性呢?我們來嘗試一下:
cat.localtion = 'Africa' print(Animal.localtion) # ==> Asia
這里依然打印了Asia,可見通過實例是無法修改類的屬性的,事實上,通過實例方法修改類屬性,只是給實例綁定了一個對應的實例屬性:
?# 新增的實例屬性 print(cat.localtion) # ==> Africa
因此,需要特別注意,盡量不要通過實例來修改類屬性,否則很容易引發意想不到的錯誤。
請把上節的 Animal類屬性 count 改為 __count,再試試能否從實例和類訪問該屬性。
把count改為私有__count,這樣實例變量在外部無法修改__count
參考代碼:
class Animal(object): __count = 0 def __init__(self, name): Animal.__count = Animal.__count + 1 self.name = name print(Animal.__count) p1 = Animal('Cat') p2 = Animal('Dog') print(Animal.__count)
請驗證,完成請求
由于請求次數過多,請先驗證,完成再次請求
打開微信掃碼自動綁定
綁定后可得到
使用 Ctrl+D 可將課程添加到書簽
舉報