• delete一个void*指针:不调用析构函数


    一个类对象,当生命周期结束时,该对象会调用自身的析构函数。

          一个类的指针,当使用delete函数来删除该指针时,会调用该指针当前类型的析构函数。

          比如:

    classB* pClass = (classB*)new classA;
    delete pClass;

          尽管该指针实际上是classA*类型,但将其转换为classB*类型,那么delete时,调用的是classB的析构函数。
          对于某些特殊类型,如void,int等,本身没有析构函数,所以若将一个类指针强转为void*,int*等,则delete时,不会调用析构函数。

         

          实际上,一个类的自然释放过程,是先执行析构函数,再逐个释放成员变量。    设classA有成员变量classAE,classB有成员变量classBE,则:

    classB* pClass = (classB*)new classA;
    delete pClass;

          会发现,先执行classB的析构函数,再执行classBE的析构函数。但实际上由于并没有classBE的存在,故也就不执行classBE的析构函数。若内部没有涉及嵌套的指针,那么这里并不会报错。
         

          故delete一个指针时,务必保证该指针的当前类型就是其定义的类型。

         

          另外,子类自然释放时,会先调用自身析构函数,再调用父类析构函数。

          设以下操作均不涉及内部指针且没有报错:

    ①   父类指针转为子类指针,并删除:会先执行子类析构函数,再执行父类析构函数

    ②   子类指针转为父类指针,并删除:会执行父类析构函数,子类析构函数不会得到调用

     所以,析构函数最好定义为Virtual。

  • 相关阅读:
    【leetcode】423. Reconstruct Original Digits from English
    【leetcode】435. Non-overlapping Intervals
    【leetcode】424. Longest Repeating Character Replacement
    【leetcode】519. Random Flip Matrix
    【leetcode】995. Minimum Number of K Consecutive Bit Flips
    【leetcode】1001. Grid Illumination
    【leetcode】1002. Find Common Characters
    【leetcode】1003. Check If Word Is Valid After Substitutions
    L95
    T61
  • 原文地址:https://www.cnblogs.com/lidabo/p/12201773.html
Copyright © 2020-2023  润新知