zoukankan      html  css  js  c++  java
  • __init__ raises an exception, then __del__ will still be called

     

    issue 808164: socket.close() doesn't play well with __del__ - Python tracker https://bugs.python.org/issue808164

     3. Data model — Python 3.8.3rc1 documentation https://docs.python.org/3/reference/datamodel.html#object.__del__

     

    Re: __init__ and __del__

    Guido.van.Rossum@cwi.nl
    Tue, 18 May 1993 16:32:23 +0200

     

    >From the responses so far I can conclude that having __init__
    explicitly call the base class's __init__ is the best possible
    solution, so let's move on to Chris' suggestion:

    > By the way, will there be a __del__(self) method that is called at
    > destruction time? My thought on this was that when python sees that an
    > object should be garbage collected, it calls the object's __del__
    > method (if any) before actually destroying it. Of course the
    > interpreter would have to check the object's refcount after calling
    > the function, as the method may have caused the object to be
    > referenced by some other object.

    The problem with this is, what to do if the __del__ call creates
    another reference to the object? You can't delete it then since the
    new reference would be dangling. But not deleting the object means
    that the __del__ method may be called again later when the reference
    count goes down to zero once again. Would this be a problem?

    > I don't really have a good example of why you'd want this, other than
    > for creating classes that keep track of how many instances of the
    > class exist. Perhaps someone else can think of a good reason for
    > having it. It just seems that if you have a function that is called at
    > object creation that you should have one that is called at object
    > destruction as well.

    Actually, there are lots of situations where a class is used as a
    wrapper around some "real-world" object (e.g. a window or a temporary
    file or an audio device) that you would want to destroy (or restore to
    a previous state) when the instance goes away. So yes, I think there
    are many cases where this would be useful.

    There's one problem with __del__, however: what if it raises an
    exception? __del__ will be called implicitly from a DECREF(x)
    statement in the C code, and I'm not going to add error checking to
    all DECREF() statements. So these exceptions will have to be ignored.
    In fact, there may already be an exception pending when DECREF() is
    called, so it may have to save and restore the original exception.
    Nasty!

    One final thing to ponder: if we have a __del__ method, should the
    interpreter guarantee that it is called when the program exits? (Like
    C++, which guarantees that destructors of global variables are
    called.) The only way to guarantee this is to go running around all
    modules and delete all their variables. But this means that __del__
    method cannot trust that any global variables it might want to use
    still exist, since there is no way to know in what order variables are
    to be deleted. Or is this not a useful feature?

    --Guido van Rossum, CWI, Amsterdam <Guido.van.Rossum@cwi.nl>

     

    Python Gotchas 1: __del__ is not the opposite of __init__ | Algorithm.co.il http://www.algorithm.co.il/blogs/programming/python-gotchas-1-__del__-is-not-the-opposite-of-__init__/

    class A:
    def __init__(self, x):
    if x == 0:
    raise Exception()
    self.x = x

    def __del__(self):
    print('__del__')
    print(self.x)


    A(1)
    A(0)

     Python Archives (1993): Re: __init__ and __del__ https://legacy.python.org/search/hypermail/python-1993/0109.html

    class A:
    def __init__(self, x):
    if x == 0:
    raise Exception()
    self.x = x

    def __del__(self):
    print('__del__')
    print(self.x)


    A(1)
    A(0)
  • 相关阅读:
    SuperSocket 日志接口
    SuperSocket 中的日志系统
    supersocket为动态命令增加命令过滤器
    如何让 jQuery Mobile 不显示讨厌的 loading 界面
    腾讯推出微信公众平台企业服务平台风铃
    微信公众平台开发(47)公交查询
    微信公众平台开发(48)星座运势
    微信公众平台开发(45)食物营养及热量查询
    微信公众平台开发(46)在线电影/移动影院
    微信公众平台开发(44)历史上的今天
  • 原文地址:https://www.cnblogs.com/rsapaper/p/12846899.html
Copyright © 2011-2022 走看看