L'ambito delle variabili create in un'istruzione with
si trova all'esterno del blocco with
(fare riferimento a: Variable defined with with-statement available outside of with-block?). Ma quando ho eseguito il seguente codice:Perché __del__ viene chiamato alla fine di un blocco con?
class Foo:
def __init__(self):
print "__int__() called."
def __del__(self):
print "__del__() called."
def __enter__(self):
print "__enter__() called."
return "returned_test_str"
def __exit__(self, exc, value, tb):
print "__exit__() called."
def close(self):
print "close() called."
def test(self):
print "test() called."
if __name__ == "__main__":
with Foo() as foo:
print "with block begin???"
print "with block end???"
print "foo:", foo # line 1
print "-------- Testing MySQLdb -----------------------"
with MySQLdb.Connect(host="xxxx", port=0, user="xxx", passwd="xxx", db="test") as my_curs2:
print "(1)my_curs2:", my_curs2
print "(1)my_curs2.connection:", my_curs2.connection
print "(2)my_curs2.connection:", my_curs2.connection
print "(2)my_curs2.connection.open:", my_curs2.connection.open # line 2
L'output mostra che Foo.__del__
si chiama prima di stampare foo (a # line 1
sopra):
__int__() called.
__enter__() called.
with block begin???
with block end???
__exit__() called.
__del__() called.
foo: returned_test_str
-------- Testing MySQLdb -----------------------
(1)my_curs2: <MySQLdb.cursors.Cursor object at 0x7f16dc95b290>
(1)my_curs2.connection: <_mysql.connection open to 'xxx' at 2609870>
(2)my_curs2.connection: <_mysql.connection open to 'xxx' at 2609870>
(2)my_curs2.connection.open: 1
La mia domanda è, perché è Foo.__del__
chiamato qui, se il L'istruzione with
non crea un nuovo ambito di esecuzione?
Inoltre, se il metodo della connessione __del__
viene chiamato nel secondo with
blocco, io non capisco perché my_curs1.connection
è ancora aperta in seguito (vedi # line 2
sopra).
Possibile duplicato di [Posso usare con istruzione con oggetto MySQLdb.Connection?] (Http://stackoverflow.com/questions/11751703/can-i-use-with-statement-with-mysqldb-connection-object) – tzaman
Chengcheng, vedi il link @ tzaman per la risposta al tuo secondo problema e rimuovi quella parte dalla tua domanda. Mantenere un problema in una domanda aiuta a mantenere ordinato StackOverflow e consente alle persone di trovare risposte più rapidamente. Grazie! – CodeMouse92
@ tzaman Questa domanda ha 3 anni e la sua risposta è errata. – Air