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)
  • 相关阅读:
    EOJ 1068 石子游戏-B
    二分图匹配(匈牙利算法模板)
    注入(3)--远程线程注入(CreateRemoteThread)
    cmd运行Java命令时编译通过,但是找不到主类或无法加载主类
    Java线程的两种实现方法
    Java String类一些操作的内存问题
    Java构造方法的继承调用
    Android布局(5)--绝对布局(AbsoluteLayout)
    Android布局(4)--相对布局(RelativeLayout)
    Android布局(3)--帧布局(FrameLayout)
  • 原文地址:https://www.cnblogs.com/rsapaper/p/12846899.html
Copyright © 2011-2022 走看看