zoukankan      html  css  js  c++  java
  • 程序执行与析构函数的调用顺序问题

    我们发现,num_count 是全局的,当每创建一个实例,__init__()被调用,num_count 的值增一,当程序结束后,所有的实例会被析构,即调用__del__() 但是此时引发了异常。查看异常为 “NoneType” 即 析构时NewClass 已经被垃圾回收,所以会产生这样的异常。

            但是,疑问来了?为什么会这样?按照C/C++等语言的经验,不应该这样啊!经过查找资料,发现:

            Python的垃圾回收过程与常用语言的不一样,Python按照字典顺序进行垃圾回收,而不是按照创建顺序进行。所以当系统进行回收资源时,会按照类名A-Za-z的顺序,依次进行,我们无法掌控这里的流程。

         明白这些,我们做如下尝试:

    1. class NewClass(object):  
    2.     num_count = # 所有的实例都共享此变量,即不单独为每个实例分配  
    3.     def __init__(self,name):  
    4.         self.name = name  
    5.         NewClass.num_count += 1  
    6.         print name,NewClass.num_count  
    7.     def __del__(self):  
    8.         NewClass.num_count -= 1  
    9.         print "Del",self.name,NewClass.num_count  
    10.     def test():  
    11.         print "aa"  
    12.   
    13. aa = NewClass("Hello")  
    14. bb = NewClass("World")  
    15. cc = NewClass("aaaa")  
    16.   
    17. del aa  
    18. del bb  
    19. del cc  
    20.   
    21. print "Over"

    区分所有的类对象公用的全局变量num_count和单个对象空间的name参数

  • 相关阅读:
    pandas read_excel 产生 Unnamed:0 列
    python 打印输出百分比符号%
    python 内存回收
    python 编码问题
    python 判断 txt 编码方式
    python 二维list取列
    python 两个list 求交集,并集,差集
    pandas Timestamp的用法
    Dataframe 取列名
    Dataframe 新增一列, apply 通用方法
  • 原文地址:https://www.cnblogs.com/wskgjmhh/p/7553860.html
Copyright © 2011-2022 走看看