扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
创新互联www.cdcxhl.cn八线动态BGP香港云服务器提供商,新人活动买多久送多久,划算不套路!
成都创新互联公司长期为上千客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为龙城企业提供专业的成都做网站、网站制作、成都外贸网站建设,龙城网站改版等技术服务。拥有10余年丰富建站经验和众多成功案例,为您定制开发。这篇文章运用简单易懂的例子给大家介绍怎么理解使用__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__方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流