最近學(xué)習(xí)《Python參考手冊》學(xué)到Class部分,遇到了類的構(gòu)造析構(gòu)部分的問題:
1、什么時候構(gòu)造?
2、什么時候析構(gòu)?
3、成員變量如何處理?
4、Python中的共享成員函數(shù)如何訪問?
------------------------
探索過程:
1、經(jīng)過查找,Python中沒有專用的構(gòu)造和析構(gòu)函數(shù),但是一般可以在__init__和__del__分別完成初始化和刪除操作,可用這個替代構(gòu)造和析構(gòu)。還有一個__new__用來定制類的創(chuàng)建過程,不過需要一定的配置,此處不做討論。
2、類的成員函數(shù)默認(rèn)都相當(dāng)于是public的,但是默認(rèn)開頭為__的為私有變量,雖然是私有,但是我們還可以通過一定的手段訪問到,即Python不存在真正的私有變量。如:
代碼如下:
__priValue = 0 # 會自動變形為"_類名__priValue"的成員變量
3、由于Python的特殊性,全局成員變量是共享的,所以類的實(shí)例不會為它專門分配內(nèi)容空間,類似于static,具體使用參看下面的例子。
測試1:
代碼如下:
# encoding:utf8
class NewClass(object):
num_count = 0 # 所有的實(shí)例都共享此變量,即不單獨(dú)為每個實(shí)例分配
def __init__(self,name):
self.name = name
NewClass.num_count += 1
print name,NewClass.num_count
def __del__(self):
NewClass.num_count -= 1
print "Del",self.name,NewClass.num_count
def test():
print "aa"
aa = NewClass("Hello")
bb = NewClass("World")
cc = NewClass("aaaa")
print "Over"
調(diào)試運(yùn)行:
代碼如下:
Hello 1
World 2
aaaa 3
Over
DeException l Hello 2
AttributeError: "'NoneType' object has no attribute 'num_count'" in <bound method NewClass.__del__ of <__main__.NewClass object at 0x01AF18D0>> ignored
Exception AttributeError: "'NoneType' object has no attribute 'num_count'" in <bound method NewClass.__del__ of <__main__.NewClass object at 0x01AF1970>> ignored
我們發(fā)現(xiàn),num_count 是全局的,當(dāng)每創(chuàng)建一個實(shí)例,__init__()被調(diào)用,num_count 的值增一,當(dāng)程序結(jié)束后,所有的實(shí)例會被析構(gòu),即調(diào)用__del__() 但是此時引發(fā)了異常。查看異常為 “NoneType” 即 析構(gòu)時NewClass 已經(jīng)被垃圾回收,所以會產(chǎn)生這樣的異常。
但是,疑問來了?為什么會這樣?按照C/C++等語言的經(jīng)驗(yàn),不應(yīng)該這樣啊!經(jīng)過查找資料,發(fā)現(xiàn):
Python的垃圾回收過程與常用語言的不一樣,Python按照字典順序進(jìn)行垃圾回收,而不是按照創(chuàng)建順序進(jìn)行。所以當(dāng)系統(tǒng)進(jìn)行回收資源時,會按照類名A-Za-z的順序,依次進(jìn)行,我們無法掌控這里的流程。
新聞熱點(diǎn)
疑難解答
圖片精選