python中類屬性和實例屬性名字衝突怎麼辦

class Person(object):
    address = 'Earth'
    def __init__(self, name):
        self.name = name

p1 = Person('Bob')
p2 = Person('Alice')

print 'Person.address = ' + Person.address

p1.address = 'China'
print 'p1.address = ' + p1.address

print 'Person.address = ' + Person.address
print 'p2.address = ' + p2.address
結果如下:

Person.address = Earth
p1.address = China
Person.address = Earth
p2.address = Earth

我們發現,在設置了 p1.address = ‘China’ 後,p1訪問 address 確實變成了 ‘China’,但是,Person.address和p2.address仍然是’Earch’,怎麼回事?
原因是 p1.address = ‘China’並沒有改變 Person 的 address,而是給 p1這個實例綁定了實例屬性address ,對p1來說,它有一個實例屬性address(值是’China’),而它所屬的類Person也有一個類屬性address,所以:
訪問 p1.address 時,優先查找實例屬性,返回’China’。
訪問 p2.address 時,p2沒有實例屬性address,但是有類屬性address,因此返回’Earth’。
可見,當實例屬性和類屬性重名時,實例屬性優先級高,它將屏蔽掉對類屬性的訪問。
當我們把 p1 的 address 實例屬性刪除後,訪問 p1.address 就又返回類屬性的值 'Earth’了:

del p1.address
print p1.address
# => Earth

可見,千萬不要在實例上修改類屬性,它實際上並沒有修改類屬性,而是給實例綁定了一個實例屬性。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章