设计一个只能在堆内存上实例化的类和一个只能在栈内存上实例化的类
2016-04-18 17:44
295 查看
只能在堆内存上实例化的类:将析构函数定义为private,在栈上不能自动调用析构函数,只能手动调用。也可以将构造函数定义为private,但这样需要手动写一个函数实现对象的构造。只能在栈内存上实例化的类:将函数operator new和operator delete定义为private,这样使用new操作符创建对象时候,无法调用operator new,delete销毁对象也无法调用operator delete。
#include <iostream> using namespace std; //只能在堆内存上实例化的类 class CHeapOnly { public: CHeapOnly() { cout << "Constructor of CHeapOnly!" << endl; } void Destroy() const { delete this; } private: ~CHeapOnly() { cout << "Destructor of CHeapOnly!" << endl; } }; //只能在栈内存上实例化的类,就是不能使用new来构造类,把operator new私有化 class CStackOnly { public: CStackOnly() { cout << "Constructor of CStackOnly!" << endl; } ~CStackOnly() { cout << "Destrucotr of CStackOnly!" << endl; } private: void* operator new(size_t size) { } void operator delete(void * ptr) { } }; int main() { CHeapOnly* pHeap = new CHeapOnly; pHeap->Destroy(); CStackOnly objStack; return 0; } //只能在堆内存上实例化的类 // 下面一个类也只能在堆内存上生成,将构造函数和析构函数都定义为private, //但是可以通过类的static函数创建对象,不过这个对象是不能被继承的。 class FinalClass { public: static FinalClass* GetInstance() { cout << "Constructor of the class" << endl; return new FinalClass; } static void DeleteInstance(FinalClass* pInstance) { cout << "Destructor of the class" << endl; delete pInstance; pInstance = 0; } private: FinalClass() {} ~FinalClass() {} }; int main() { FinalClass* fc = FinalClass::GetInstance(); FinalClass::DeleteInstance(fc); return 0; }
相关文章推荐
- 一个关于if else容易迷惑的问题
- 一道sql面试题附答案
- C# 超高面试题收集整理
- 人人网javascript面试题 可以提前实现下
- PHP中设置一个严格30分钟过期Session面试题的4种答案
- 据说是雅虎的一份PHP面试题附答案
- php牛逼的面试题分享
- 一套比较完整的javascript面试题(部分答案)
- 10个经典的Java main方法面试题
- 小米公司JavaScript面试题
- 超级全面的PHP面试题整理集合第1/2页
- 极易被忽视的javascript面试题七问七答
- 5个实用的shell脚本面试题和答案
- PHP经典面试题集锦
- 8个PHP数组面试题
- PHP中提问频率最高的11个面试题和答案
- 用PHP解决的一个栈的面试题
- Android工程师面试题大全
- PHP面试题之文件目录操作
- 几道坑人的PHP面试题 试试看看你会不会也中招