设计一个只能在堆上或栈上的类
来源:互联网 发布:蛋鸡存栏量数据 编辑:程序博客网 时间:2024/06/06 18:36
一道C++笔试题:设计一个只能在堆内存上实例化的类和一个只能在栈内存上实例化的类
只能在堆内存上实例化的类:将析构函数定义为private,在栈上不能自动调用析构函数,只能手动调用。也可以将构造函数定义为private,但这样需要手动写一个函数实现对象的构造。
using namespace std;
//只能在堆内存上实例化的类
class CHeapOnly
{
public:
CHeapOnly()
{
cout << "Constructor of CHeapOnly!" << endl;
}
void Destroy() const
{
delete this;
}
private:
~CHeapOnly()
{
cout << "Destructor of CHeapOnly!" << endl;
}
};
{
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;
}
只能在堆内存上实例化的类:将析构函数定义为private,在栈上不能自动调用析构函数,只能手动调用。也可以将构造函数定义为private,但这样需要手动写一个函数实现对象的构造。
只能在栈内存上实例化的类:将函数operator new和operator delete定义为private,这样使用new操作符创建对象时候,无法调用operator new,delete销毁对象也无法调用operator delete。
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私有化
operator new 函数用来为对象分配原始内存。New 操作符的第一步调用的就是operator new 。你可以重载这个函数。它的原型如下:
Void* operator new(size_t size);
函数的返回值是void*, 因为这个函数返回的是指针。这个指针指向原生的,为初始化的内存。其语义就像malloc 。实际上它内部调用的就是malloc 。参数size 指定待分配的内存大小。你可以在重载的时候加上额外的参数,但是第一个参数类型必须是size_t.
{
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;
}
0 0
- 设计一个只能在堆上或栈上实例化的类
- 设计一个只能在堆上或栈上实例化的类
- 设计一个只能在堆上或栈上实例化的类
- 设计一个只能在堆上或栈上实例化的类
- 设计一个只能在堆上或栈上实例化的类
- 设计一个只能在堆上或栈上实例化的类
- 设计一个只能在堆上或栈上的类
- 如何定义一个只能在堆上(或栈上)生成对象的类
- 设计一个类只能在堆(栈)上创建
- [C++]限制一个类的对象只能在栈或堆上创建
- 如何定一个只能在堆上或者只能在栈上定义的类
- C++限制一个类只能在堆上或栈上分配
- 设计只能在堆或者栈上创建的类
- 设计只能在堆或者栈上创建的类
- 设计只能在堆或者栈上创建的类
- 创建一个不能被继承的类和只能在堆上(或栈上)创建对象
- 设计一个类不能被继承;只能在堆上创建对象;只能在栈上创建对象
- 根据类(不能被继承、只能在栈上/堆上创建对象)的特点设计一个类
- Heaters
- HDOJ--2032 杨辉三角问题(水题)
- 在java中使用jxl操作excel
- Codeforces 801C Voltage Keepsake
- Problem F: 二进制类(1)__运算符重载 hzauoj
- 设计一个只能在堆上或栈上的类
- uva12545比特变换器
- Visual Studio 2010 使用
- 编译安装PHP,解决问题 Don't know how to define struct flock on this system, set --enable-opcache=no
- 对大数(BigInteger)进行开方运算
- C#之Switch分支语句
- 20153724——2
- 【LeetCode】Student Attendance Record I 解题报告
- 2016东莞市特长生考试 字串距离