实现只能在堆上实现对象的创建:
C++98中的实现方法:
只能在堆上创建对象----就是阻止在栈上创建空间。
实例化对象有两个过程:开辟空间 和 初始化对象----调用函数意味着在栈
上开辟空间,所以只要阻止初始化,也就是禁止使用构造函数即可-----构造函数私
有化,这样就在类外不能访问构造函数了---但是副作用是即使用new在堆上申请的空
间也无法使用构造函数进行初始化了---和对象没有关系的调用函数是静态函数---所
以在类中可以定义一个静态函数用来实例化对象---防拷贝构造函数(因为可以用堆上
创建一个对象(此时是类类型的 指针变量),对这个变量进行解引用可以得到对象,
用这个对象作为拷贝构造函数的参数,就会造成在栈上也可以创建对象了)---如何防
止调用拷贝构造函数----显式定义出来,编译器就不会生成默认的拷贝构造函数了--
-考虑到如果显式定义的拷贝构造函数给成公有的权限,在类外就能调用这个拷贝构造
函数,所以拷贝构造函数必须给成私有的---由于我们的目的是为了不使用拷贝构造函
数,所以在私有条件下只给声明就行了
C++11 新的语法:
Test(const Test& t) = detele; 会使得拷贝构造函数无法生成,也就是
告诉编译器将该函数删除掉。
Test(const Test& t) = default; 告诉编译器,让编译器生成默认的函数
代码如下:
//只能在堆上创建对象
#include<iostream>
using namespace std;
class Test
{
public:
static Test* CreateInstance(int data)
{
return new Test(data); //因为该函数是成员函数,所以在类内可以调用私有的成员,因此可以调用构造函数
}
~Test()
{
cout << "~Test():" << this << endl;
}
//Test(const Test& t) = delete; //C++11 中给出的新语法,告诉编译器将该函数删除掉
private:
Test(int data)
{
cout << "Test():" << this << endl;
}
Test(const Test& t); //自己定义拷贝构造函数了,编译器就不会生成默认的拷贝构造函数 这个拷贝构造函数只能私有,因为如果公有了,别人可以在类外进行定义 如:Test::Test(const Test& t){ }
private:
int _data;
};
//Test t(10); //全局作用域中,也不能在栈上创建对象
int main()
{
//Test t1;
// Test* pt = (Test*)malloc(sizeof(Test));
//Test* pt = new Test;
Test* pt = Test::CreateInstance(5);
//Test t2(*pt); //这是在栈上创建的对象,利用了拷贝构造函数
delete pt;
return 0;
}
实现只能在栈上实现对象的创建:
只能在栈上创建对象,既不能在堆上创建对象,因此只要将new的功能屏蔽掉即可,即屏蔽掉operator new 和 定位new表达式,注意:屏蔽了operator new,实际上也是将定位new屏蔽掉。
//实现只能在栈上创建对象
class StackOnly
{
public:
StackOnly() {}
private:
void* operator new(size_t size);
void operator delete(void* p);
};