设计一个只能在堆上或栈上实例化的类
作者:网络转载 发布时间:[ 2013/6/17 10:12:04 ] 推荐标签:
一道C++笔试题:设计一个只能在堆内存上实例化的类和一个只能在栈内存上实例化的类
只能在堆内存上实例化的类:将析构函数定义为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()
{
//use of CHeapOnly
CHeapOnly* pHeap = new CHeapOnly;
pHeap->Destroy();
//error use of CHeapOnly
//CHeapOnly objHeap;
//use of CStackOnly
CStackOnly objStack;
//error use of CStackOnly
//CStackOnly* pStack = new CStackOnly;
return 0;
}
下面一个类也只能在堆内存上生成,将构造函数和析构函数都定义为private,但是可以通过类的static函数创建对象,不过这个对象是不能被继承的。
#include <iostream>
using namespace std;
//只能在堆内存上实例化的类
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()
{
//use of CHeapOnly
FinalClass* fc = FinalClass::GetInstance();
FinalClass::DeleteInstance(fc);
return 0;
}
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11