温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++中怎么使用try/catch

发布时间:2021-11-24 11:58:45 来源:亿速云 阅读:244 作者:iii 栏目:大数据

这篇文章主要介绍“C++中怎么使用try/catch”,在日常操作中,相信很多人在C++中怎么使用try/catch问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++中怎么使用try/catch”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

E.18:最小限度显式使用try/catch

Reason(原因)

try/catch结构冗长,非平凡的用法容易出错。try/catch可以看作是非系统化和低层次资源管理或错误处理的信号。

Example, Bad(反面示例)

void f(zstring s)
{
   Gadget* p;
   try {
       p = new Gadget(s);
       // ...
       delete p;
   }
   catch (Gadget_construction_failure) {
       delete p;
       throw;
   }
}

代码很凌乱。try代码块中的原始指针可能发生内存泄露。不是所有的异常都会被处理。删除一个构建失败的对象机会当然是一个错误。较好的做法:

void f2(zstring s)
{
   Gadget g {s};
}
Alternatives(其他选项)
  • proper resource handles and RAII

  • 正确使用资源句柄和RAII。

  • finally

  • finally处理

到此,关于“C++中怎么使用try/catch”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI