构造函数抛异常

在构造函数中,想知道这个类是否按期望那样是否构造成功,很多人是喜欢在构造失败情况下抛出一些异常。例:
class A1
{
public:
 A1()
 {
  pI = new int;
  cout << "A1()" << endl;
  // something error;
  throw("A1 error");
 }
 ~A1()
 {
  delete pI;
  cout << "~A1()" << endl;
 }
private:
 int *pI;
};
int _tmain(int argc, _TCHAR* argv[])
{
 A1 * pA1;
 try{
  pA1 = new A1;
 }
 catch(char* err)
 {
  cout << "A1 expection:" << err << endl;
 }
 return 0;
}
 
这个程序在执行完成以后输出的结果是:
A1()
A1 expection:A1 error
可见析构函数并没有被调用,这样子的话就产生了内存泄漏。所以如果要在构造函数抛出异常之前,应该先把已经成功分配的资源释放掉,如:

A1()
 {
  pI = new int;
  cout << "A1()" << endl;

  // something error;
  if (pI != NULL)
  {
    delete pI;
  }
  throw("A1 error");
 }
如果你在catch到一个类构造时异常之后,再对这个类进行析构,
try{
  pA1 = new A1;
 }
 catch(char* err)
 {
  cout << "A1 expection:" << err << endl;
  delete pA1;
 }
这样的话,反而弄巧成拙,加上delete pA1会使你的程序完全崩溃。
 

最后,个人提议,在构造函数中不要做过多的事情,只是能对成员变量的做初始化工作就好了。真的需要做其他复杂的初始化操作,完全可以提供一个Init或Start函数.

posted @   问笑  阅读(269)  评论(0编辑  收藏  举报
编辑推荐:
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
阅读排行:
· PPT革命!DeepSeek+Kimi=N小时工作5分钟完成?
· What?废柴, 还在本地部署DeepSeek吗?Are you kidding?
· DeepSeek企业级部署实战指南:从服务器选型到Dify私有化落地
· 程序员转型AI:行业分析
· 重磅发布!DeepSeek 微调秘籍揭秘,一键解锁升级版全家桶,AI 玩家必备神器!
点击右上角即可分享
微信分享提示