标签:c class-design
我知道有一些方法可以阻止用户使用new和delete操作符来阻止在堆上创建类.我正试图做相反的事情.我有一个类,我想阻止用户在堆栈上创建它的实例,并且只有使用new运算符发起的实例才会编译.更具体地说,我希望以下代码在编译期间收到错误:
MyClass c1; //compilation error
MyClass* c1 = new MyClass(); //compiles okay
通过搜索网络,我发现了如何做到这一点的建议:
class MyClass {
public:
MyClass();
private:
void destroy() const { delete this; }
...
private:
~MyClass();
};
int main(int argc,char** argv)
{
MyClass myclass; // <--- error, private destructor called here !!!
MyClass* myclass_ptr = new MyClass;
myclass_ptr->destroy();
}
我不明白为什么这应该工作.为什么在创建MyClass实例时会调用析构函数?
解决方法:
当myclass到达其作用域的末尾(下一个})时,编译器会调用析构函数将其从堆栈中释放出来.但是,如果析构函数是私有的,则无法访问析构函数,因此无法将类放在堆栈上.
我不喜欢删除它的外观.总的来说,我认为对象不应该破坏自己.也许更好的方法是为您的类创建一个私有构造函数,然后使用静态函数来创建实例.
// In class declaration...
static MyClass* Create()
{
return new MyClass(); // can access private constructor
}
// ...
MyClass myclass; // illegal, cannot access private constructor
MyClass* pMyClass = MyClass::Create();
delete pMyClass; // after usage
标签:c,class-design 来源: https://codeday.me/bug/20191004/1852354.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。