C++ 类的实例化方式限制

  在C++中,类的实例化可以 A a; 或者 A *p = new A; ,有的时候想只能用其中一个中方式实例化。

一、只能静态分配类对象,即 A a; 的方式进行实例化

  这样需要将类的 new 和 delete 操作符重载为 protected,new[] 、delete[] 同理,如下:

class A
{
public:

protected:
	void* operator new(size_t) { return nullptr; };	// 函数的第一个参数与返回值类型是固定的
	void operator delete(void*) { };				// 重载了new,就要重载delete

	void* operator new[](size_t) { return nullptr; };
	void operator delete[](void*) { };
};

int main()
{
	A *a1 = new A;		// not ok, A::operator new   不可访问
	A *a2 = new A[];	// not ok, A::operator new[] 不可访问
	A a3;				// ok

	return 0;
}

二、只能动态分配类对象,即 A *p = new A; 的方式进行实例化

  把类的构造函数和析构函数设为protected属性。类对象不能访问,但是派生类可以继承,也可以访问。还需要创建 create 和 destroy 两个函数,用于创建和销毁类的对象,不然 new A 的时候会报错说构造函数是 non-public 的不可访问。设为 static 是因为创建对象时候只能用类名访问,即 A::create();。

class A
{
protected:
	A() = default;
	~A() = default;

public:
	static A* create()
	{
		return new A();
	}
	static void destroy(A* p)
	{
		delete p;	// 不要用 delete this;
	}
};

int main()
{
	A *p = A::create();
	A::destroy(p);

	return 0;
}

猜你喜欢

转载自blog.csdn.net/Bob__yuan/article/details/88943378