首頁  >  文章  >  後端開發  >  Python的類別實例屬性存取規則

Python的類別實例屬性存取規則

高洛峰
高洛峰原創
2016-10-19 15:22:261292瀏覽

一般來說,在Python中,類別實例屬性的存取規則算是比較直觀的。

但是,仍然存在一些不是很直觀的地方,特別是對C++和Java程式設計師來說,更是如此。

在這裡,我們需要明白以下幾個地方:

1.Python是一門動態語言,任何實體都可以動態地添加或刪除屬性。

2.一個類別定義了一個作用域。

3.類別實例也引入了一個作用域,這與對應類別定義的作用域不同。

4.在類別實例中查找屬性的時候,首先在實例自己的作用域中查找,如果沒有找到,則再在類別定義的作用域中查找。

5.在對類別實例屬性進行賦值的時候,實際上會在類別實例定義的作用域中添加一個屬性(如果還不存在的話),並不會影響到相應類別中定義的同名屬性。

下面看一個例子,加深對上述幾點的理解:

class A:

cls_i = 0

cls_j = {}

def __init__(self):🜎 instance_j = {}

在這裡,我們先定義類別A的一個實例a,然後再看看類別A的作用域和實例a的作用域中分別有什麼:

>>> a = A()

>>> a.__dict__

{'instance_j': {}, 'instance_i': 0}

>>> A.__dict__

{'__init__': , '__module__': 'modmod__, ' : 0, 'cls_j': {}, '__doc__': None}

我們看到,a的作用域中有instance_i和instance_j,A的作用域中有cls_i和cls_j。

我們再來看看名字查找是如何發生的:

>>> a.cls_i

0

>>> a.instance_i

0

在查找實例中的作用是例子的時候,是實例在cls的作用沒有它的,卻在A的作用域中找到了它;在查找instance_i的時候,直接可在a的作用域中找到它。

如果我們企圖透過實例a來修改cls_i的值,那會怎麼樣呢:

>>> a.cls_i = 1

>>> a.__dict__

{'instance_j': {), 'cls_i' : 1, 'instance_i': 0}

>>> A.__dict__

{'__init__': , '__module__': '__main__', 'cls_i': 0, 'cls_j': {}, '__main__': None}

我們可以看到,a的作用域中多了一個cls_i屬性,其值為1;同時,我們也注意到A作用域中的cls_i屬性的值仍然為0;在這裡,我們其實是增加了一個實例屬性,並沒有修改到類別屬性。

如果我們透過實例a來操縱cls_j中的資料(注意不是cls_j本身),又會怎麼樣呢:

>>> a.cls_j['a'] = 'a'

>>> a.__dict__

{'instance_j': {}, 'cls_i': 1, 'instance_i': 0}

>>> A.__dict__

{'__init__': , '__module__': '__

{'__init__': , '__module__': '__

, 'cls_main_i 0, 'cls_j': {'a': 'a'}, '__doc__': None}

我們可以看到a的作用域沒有發生什麼變化,但是A的作用域發生了一些變化,cls_j中的數據發生了變化。

實例的作用域發生變化,並不會影響到該類別的其它實例,但是類別的作用域發生變化,則會影響到該類別的所有實例,包括在這之前創建的實例:

>> > A.cls_k = 0

>>> i.cls_k

0


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn