Python類變量和實(shí)例變量,傻傻分不清楚
一、前言
前幾天在Python最強(qiáng)王者交流群有個叫【Chloé】的粉絲問了一個關(guān)于Python類變量和實(shí)例變量的問題,這里拿出來給大家分享下,一起學(xué)習(xí)。
這個粉絲在法國留學(xué),所以提問是英文的,當(dāng)然了英文看上去也不難,有點(diǎn)二級英文基礎(chǔ),也看得懂,實(shí)在不行,在線翻譯一下也問題不大了。
二、解決過程
這里給出【??(這是月亮的背面)】大佬的解答:
這里主要涉及到三個部分,類屬性,實(shí)例屬性,及實(shí)例屬性的引用對象指向性問題。在該例中counter為類屬性,__first為實(shí)例屬性,print函數(shù)中的counter為實(shí)例屬性的引用對象指向性問題。當(dāng)ExampleClass類實(shí)例化時,__init__魔法函數(shù)會自動執(zhí)行其下方的代碼段,而下方代碼段涉及到兩種屬性的變化,實(shí)例屬性為該實(shí)例化對象特有的,即實(shí)例化完成后才會存在,每個實(shí)例化對象之間的實(shí)例屬性是獨(dú)立的,從你下方的print打印結(jié)果也能看出,實(shí)例對象.__dict__輸出當(dāng)前實(shí)例化對象的實(shí)例屬性。而類屬性只要定義完類,就已經(jīng)存在,使用類.類屬性可以引用該類屬性,也可以進(jìn)行修改,類屬性是所有實(shí)例化對象共享的,在此例中每次實(shí)例化類后,ExampleClass.counter都會加1,在三次print中能看到輸出值都是一樣。
【月神】在這里還多了一些拓展。
在__init__中,在ExampleClass.counter += 1前添加了一行self.counter += 1;這里說明下實(shí)例屬性的引用方式,在類實(shí)例化后,首先引用實(shí)例屬性已有的,而如果找不到會往上尋找,即找類屬性,在修改后的代碼里,我為實(shí)例對象增加了一個實(shí)例屬性counter,在print里的實(shí)例對象.__dict__也能看到實(shí)例屬性中存在counter,而此時實(shí)例對象.counter引用到的是實(shí)例屬性,而非類屬性。這里再說一下為什么self.counter += 1能夠正常執(zhí)行,上述說到實(shí)例屬性的引用會向上尋找,則進(jìn)行+= 1計算時,會引用類屬性,第一次實(shí)例化中,類屬性下的counter為0,加1后賦值給實(shí)例屬性下的counter,那么第一個實(shí)例對象的counter打印出來就是1,第二次實(shí)例化,在第一次實(shí)例化的過程中,類屬性下counter也進(jìn)行了加1,反映到第二次中,使用到的類屬性counter此時已經(jīng)為1,進(jìn)行加1賦值給第二次實(shí)例屬性的counter,即2,第三次類似。
三、總結(jié)
針對Python類變量和實(shí)例變量的問題,給出了具體說明和演示,順利地幫助粉絲解決了問題。
總的來說,類變量:可在類的所有實(shí)例之間共享的值(也就是說,它們不是單獨(dú)分配給每個實(shí)例的)。實(shí)例變量:實(shí)例化之后,每個實(shí)例單獨(dú)擁有的變量。
類變量和實(shí)例變量的區(qū)別在于:類變量是所有對象共有,其中一個對象將它值改變,其他對象得到的就是改變后的結(jié)果;而實(shí)例變量則屬對象私有,某一個對象將其值改變,不影響其他對象。