C++销毁一个自定义对象后,它里面的成员方法去哪儿了?-创新互联

#include 
using namespace std;

class TestClass
{
public:
	void Print()
	{
		cout << "hello" << endl;
		//_a++;
	}

protected:
	//int _a = 0;
};

int main()
{
	TestClass *tc = new TestClass();
	delete tc;
	tc = NULL;
	tc->Print();
	return 0;
}

类似如上模型的代码 坑了我好久

十余年专注建站、设计、互联网产品专业公司服务,业务涵盖品牌网站建设商城网站建设、小程序定制开发、软件系统开发、手机APP定制开发等。凭借多年丰富的经验,我们会仔细了解每个客户的需求而做出多方面的分析、设计、整合,为客户设计出具风格及创意性的商业解决方案,创新互联建站更提供一系列网站制作和网站推广的服务,以推动各中小企业全面信息数字化,并利用创新技术帮助各行业提升企业形象和运营效率。

下面是我今天下午的遭遇:

注意main函数中,我首先申请了一块 tc类型的对象

紧接着我把它delete 并将指向它的指针置为NULL了

然而这时候,执行 tc->Print()  是可以的,程序可以输出 hello

但如果紧接着将代码中的2行注释放开,也就是在类中定义一个成员对象a,并在成员方法Print中访问这个对象,程序立马挂掉,而这不论是g++ 还是 Visual Studio 在编译的过程中都是不会报错的

为什么会这样呢?

原因很简单

C++  销毁一个自定义对象后,它里面的成员方法去哪儿了?

一个对象,定以后,成员对象和成员方法都存放在代码段

一旦new 出来这个对象, 其中的成员对象是跟对象本身一起存放在堆区的,

可是,成员方法(非静态) 依然放在代码段

所以,在析构、销毁对象的时候,只会把堆中的东西,也就是成员对象delete掉,

所以这时候是能访问进成员对象的

而C++这么做,是为了节省资源,毕竟相同类型的不同对象之间,可能又不同的成员对象,但它们的成员方法(非静态)都是可以通用的

而这个问题,编译器目前是检查不出来的,因为编译器查错是在代码执行前进行的,而这个问题是代码执行的过程中产生的

这种问题一旦出现确实不太好找,不过归根到底 都是水平太菜啊。。

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


新闻名称:C++销毁一个自定义对象后,它里面的成员方法去哪儿了?-创新互联
标题URL:http://scyanting.com/article/ehchg.html