C++ delete
#include<iostream>
class A{
public:
void t(){
std::cout<< "hello world!" << std::endl;
}
~A(){
std::cout<< "调用析构函数" << std::endl;
}
int a;
};
int main(){
A *p = new A;
p->a = 2;
delete p;
p->t();
std::cout << "p->a:" << p->a << std::endl;
return 0;
}
输出:
调用析构函数
hello world!
p->a:0
delete p操作首先会调用p指向对象的析构函数,然后将成员变量a置空。
delete操作并没有将t()删除,因为t()是所有对象共有的。
在这段代码中,p指向的内存空间已经被释放,delete操作将其所指向的内存空间标记为可用,但并没有将指针p本身变为NULL或者指向其他有效的内存地址,所以在尝试使用p指针时,它仍然指向之前已经释放的内存地址。这种情况被称为“悬挂指针”(dangling pointer),使用悬挂指针可能导致未定义的行为(undefined behavior),包括程序崩溃、数据损坏等。(未定义行为:每个编译器可能都有不同的实现,C++标准中并未有明确的定义)
查看对象占用的内存空间,就会发现内存空间中只存储了对象中的数据成员。所以我认为肯定是有一个表用于说明“哪个地址上的东西属于哪个类型”。
还可以参考链接进行学习。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?