我们在上一篇文章中为大家介绍了产生C++堆对象禁用的具体实现方式,相信大家应该有所掌握。今天我们将会为大家介绍同属于内存逻辑区域的C++栈对象的禁用方式。希望能让大家进一步对这方面的应用技巧有一个深刻的认识。#t#
创新互联是一家以重庆网站建设公司、网页设计、品牌设计、软件运维、营销推广、小程序App开发等移动开发为一体互联网公司。已累计为混凝土搅拌罐等众行业中小客户提供优质的互联网建站和软件开发服务。
创建C++栈对象时会移动栈顶指针以“挪出”适当大小的空间,然后在这个空间上直接调用对应的构造函数以形成一个栈对象,而当函数返回时,会调用其析构函数释放这个对象,然后再调整栈顶指针收回那块栈内存。在这个过程中是不需要operat or newdelete操作的,所以将operator newdelete设置为private不能达到目的。当然从上面的叙述中,你也许已经想到了:将构造函数或析构函数设为私有的,这样系统就不能调用构造析构函数了,当然就不能在栈中生成对象了。
这样的确可以,而且我也打算采用这种方案。但是在此之前,有一点需要考虑清楚,那就是,如果我们将构造函数设置为私有,那么我们也就不能用new来直接产生堆对象了,因为new在为对象分配空间后也会调用它的构造函数啊。所以,我打算只将析构函数设置为private。再进一步,将析构函数设为private除了会限制栈对象生成外,还有其它影响吗?是的,这还会限制继承。
如果一个类不打算作为基类,通常采用的方案就是将其析构函数声明为private。
为了限制C++栈对象,却不限制继承,我们可以将析构函数声明为protected,这样就两全其美了。如下代码所示:
- class NoStackObject
- {
- protected
- ~NoStackObject() { }
- public
- void destroy()
- {
- delete this ;调用保护析构函数
- }
- };
接着,可以像这样使用NoStackObject类:
- NoStackObject hash_ptr = new NoStackObject() ;
- ... ... 对hash_ptr指向的对象进行操作
- hash_ptr-destroy() ;
是不是觉得有点怪怪的,我们用new创建一个对象,却不是用delete去删除它,而是要用destroy方法。很显然,用户是不习惯这种怪异的使用方式的。所以,我决定将构造函数也设为private或protected。这又回到了上面曾试图避免的问题,即不用new,那么该用什么方式来生成一个对象了?我们可以用间接的办法完成,即让这个类提供一个static成员函数专门用于产生该类型的堆对象。(设计模式中的singleton模式就可以用这种方式实现。)让我们来看看:
- class NoStackObject
- {
- protected
- NoStackObject() { }
- ~NoStackObject() { }
- public
- static NoStackObject creatInstance()
- {
- return new NoStackObject() ;调用保护的构造函数
- }
- void destroy()
- {
- delete this ;调用保护的析构函数
- }
- };
现在可以这样使用NoStackObject类了:
- NoStackObject hash_ptr = NoStackObjectcreatInstance() ;
- ... ... 对hash_ptr指向的对象进行操作
- hash_ptr-destroy() ;
- hash_ptr = NULL ; 防止使用悬挂指针
以上就是对C++栈对象进行限制的相关操作方法。
网页标题:C++栈对象产生禁用方式
路径分享:http://www.mswzjz.cn/qtweb/news49/284199.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能