析构函数的调用由对象生命周期严格决定:栈对象在离开作用域时逆序析构;new对象需delete显式触发;临时对象在完整表达式结束时析构;异常时自动栈展开析构已构造对象;析构函数应noexcept以确保异常安全。

析构函数不是“随时能调”或“手动触发”的,它的执行完全由对象的生命周期决定,且有明确、不可绕过的规则。
对象离开作用域时自动调用析构函数
这是最常见的情形。栈上创建的对象(即局部对象),在其所在代码块结束(如右大括号 })时立即执行析构函数,顺序与构造相反——后构造的先析构。
- 函数内定义的局部对象:函数返回前完成析构
- for 循环内定义的对象:每次迭代结束时析构(若在循环体内声明)
- if 语句块中定义的对象:仅当该分支被执行,且离开该分支作用域时析构
动态分配对象需显式 delete 才触发析构
用 new 创建的对象不会自动析构;必须配对使用 delete(或 delete[] 对应数组),此时才会调用析构函数并释放内存。
- 忘记 delete → 析构不执行 → 资源泄漏(如文件句柄、内存、锁未释放)
- 重复 delete → 未定义行为(可能崩溃或静默出错)
- 建议优先使用智能指针(如 std::unique_ptr),它在自身析构时自动调用所管对象的析构函数
临时对象在完整表达式结束时析构
函数返回的匿名临时对象、类型转换产生的中间对象等,在包含它的完整表达式求值结束后立即析构(C++17 后部分场景有强制拷贝省略,但析构时机不变)。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~