色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

談談Python:為什么類中的私有屬性可以在外部賦值并訪問

瀏覽:7日期:2022-08-04 08:49:42

Python:為什么類中的私有屬性可以在外部賦值并訪問?

問題引入

在慕課網上學習Python**類中的私有屬性**的時候,看到了一個同學的提問:

將count改為__count,為什么實例變量在外部仍然可以修改__count?這里print p1.__count可以打印出100

class Person(object): __count = 0 def __init__(self, name): Person.__count = Person.__count + 1 self.name = name print Person.__count p1 = Person(’Bob’) p1.__count=100 print p1.__count p2 = Person(’Alice’)print Person.__count

問題解決:

單刀直入版:

這是因為給p1.__count賦值的操作,其實是在p1中定義了一個名為__count的變量(因為Python中的都是動態變量),而沒有改變類中真正的屬性。

太長但還是要看看版:

知識點清單:

1、類的“偽私有屬性” 2、在類的外部動態地創建類屬性

問題解決過程:

1、“偽私有屬性”的概念:

python的類中通過加雙下劃線來設置的“私有屬性”其實是“偽私有屬性”,原理是python編譯器將加了雙下劃線的“屬性名”自動轉換成“類名屬性名”。所以我們在外部用“屬性名”訪問私有屬性的時候,會觸發AttributeError,從而實現“私有屬性”的特性。但通過“類名屬性名”也可以訪問這些屬性。

參考:http://www.pythonclub.org/python-class/private

2、編寫測試代碼:

以下是在該同學的代碼的基礎上修改的測試代碼:

class Person(object): #設置類屬性 __count_of_class = ’original count_of_class’ def __init__(self, name): self.name = name print(’in class Person : count_of_class = ’, Person.__count_of_class,’n’)#初始化實例p1p1 = Person(’Bob’)#在實例p1上修改屬性值p1.__count_of_class=’I’m not the original count_of_class!’print(’p1’s _Person__count_of_class = ’,p1._Person__count_of_class)print(’p1’s __count_of_class = ’,p1.__count_of_class,’n’)#在類Person上修改屬性值Person.__count_of_class = ’I’m not the original count_of_class!’#將這句注釋取消掉,會發現真正的私有屬性的值也改變了#Person._Person__count_of_class = ’I’m not the original count_of_class!’print(’Person’s _Person__count_of_class = ’,Person._Person__count_of_class)print(’Person’s __count_of_class = ’,Person.__count_of_class)

分別在實例p1上和類Person上進行操作,并且分別打印出“__屬性名”,以及“_類名__屬性名”。

輸出結果如下:

in class Person : count_of_class = original count_of_classp1’s _Person__count_of_class = original count_of_classp1’s __count_of_class = I’m not the original count_of_class!Person’s _Person__count_of_class = original count_of_classPerson’s __count_of_class = I’m not the original count_of_class!

**由此可見,雖然用p1.__count_of_class給它賦值了,但其實在類中真正的屬性_Person__count_of_class的原始值是沒有改變的。

但是如果將p1._Person__count_of_class賦值,那么類屬性定義的原始值就真正地被覆蓋了**

'''取消掉##Person._Person__count_of_class = ’I’m not the original count_of_class!’的注釋,輸出結果:'''in class Person : count_of_class = original count_of_class p1’s _Person__count_of_class = original count_of_class p1’s __count_of_class = I’m not the original count_of_class! #注意這一句:Person’s _Person__count_of_class = I’m not the original count_of_class! Person’s __count_of_class = I’m not the original count_of_class!

由此,我們知道了:_count_of_class和_Person_count_of_class不是同一個東西。

最后的問題

但是呢,如果不先給p1.__count_of_class賦值,直接打印它又會觸發AttributeError,這是為什么?

這是因為給p1.__count_of_class賦值的操作,其實是在p1中定義了一個名為__count_of_class的變量(因為Python中的都是動態變量)。

以下實例說明可以通過外部賦值來為類創造屬性:

class Person(object): passp1=Person()#給p1創建屬性new_of_instancep1.new_of_instance = ’I’m new in p1!’print(p1.new_of_instance)#給Person類創建屬性new_of_classPerson.new_of_class = ’I’m new in Person!’#在類中新加的屬性,可以通過實例來訪問print(p1.new_of_class)>>>輸出:I’m new in p1!I’m new in Person!

問題解決。

以上這篇談談Python:為什么類中的私有屬性可以在外部賦值并訪問就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 成年人免费在线视频观看 | 久久是精品 | 国产成人精品视频免费大全 | 日本国产欧美色综合 | 日本在线视频免费看 | 视频一区中文字幕 | 国产成人精品男人的天堂538 | 亚洲伦| 久久国产精品歌舞团 | 天天躁夜夜躁狠狠躁2024 | 欧美一区二区二区 | 热久久在线观看 | 欧美另类视频在线观看 | 三级com | 222aaa天堂| 五月久久噜噜噜色影 | 亚洲精品综合一区二区三区在线 | 国产视频久 | 日韩一品在线播放视频一品免费 | 亚洲一级毛片视频 | 黄色一级片网址 | 一级国产交换配乱淫 | 欧美日韩在线视频免费完整 | 日本成人免费在线 | 国产一区二区三区手机在线观看 | 午夜福利国产一级毛片 | 久久久小视频 | 国产午夜亚洲精品理论片不卡 | 亚洲精品99久久久久久 | 亚洲一区二区三区久久久久 | 午夜成年女人毛片免费观看 | 在线观看中文字幕国产 | 日韩精品中文字幕一区三区 | 最新国产精品视频免费看 | 国产日韩精品欧美一区 | 欧美怡红院在线 | 999成人国产精品 | 国产日韩欧美在线观看播放 | 91精品国产91久久久久久青草 | 9999毛片免费看 | 亚洲国产激情 |