您好,登錄后才能下訂單哦!
這篇文章運用簡單易懂的例子給大家介紹怎么理解使用__del__方法,代碼非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
錯誤的使用__del__方法
假設有一個文件mod.py中這樣使用:
import foo class Bar(object): ... def __del__(self): foo.cleanup(self.myhandle)
然后試圖在another_mod.py里這樣:
import mod mybar = mod.Bar()
那么你會得到一個惡心的AttributeError異常。
為啥呢?這是因為(參考這里),當解釋器關閉時,模塊所有的全局變量會被置為空(None)。結果便如上例所示,當__del__被調用時,名字foo已經被置為空了。
使用atexit.register()可以解決這個問題。如此,當你的程序結束的時候(退出的時候),你的注冊的處理程序會在解釋器關閉之前處理。
這樣理解的話,對上面的mod.py可以做如下的修改:
import foo import atexit def cleanup(handle): foo.cleanup(handle) class Bar(object): def __init__(self): ... atexit.register(cleanup, self.myhandle)
關于怎么理解使用__del__方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。