C++异常处理怎么用

本篇内容介绍了“C++异常处理怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联建站专注于企业营销型网站、网站重做改版、泸水网站定制设计、自适应品牌网站建设、HTML5建站成都做商城网站、集团公司官网建设、外贸营销网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为泸水等各大城市提供网站开发制作服务。

E.3:异常应该只用于错误处理

Reason(原因)

To keep error handling separated from "ordinary code." C++ implementations tend to be optimized based on the assumption that exceptions are rare.

保证错误处理和“普通的代码”分离。C++的实现试图以异常处理很罕见为前提进行代码优化。

Example, don't(反面示例)

// don't: exception not used for error handling
int find_index(vector& vec, const string& x)
{
   try {
       for (gsl::index i = 0; i < vec.size(); ++i)
           if (vec[i] == x) throw i;  // found x
   }
   catch (int i) {
       return i;
   }
   return -1;   // not found
}

This is more complicated and most likely runs much slower than the obvious alternative. There is nothing exceptional about finding a value in a vector.

相比于显而易见的其他做法,这段代码更复杂,很有可能执行地更慢。在vector中发现一个值没有什么意外性。

Enforcement(实施建议)

Would need to be heuristic. Look for exception values "leaked" out of catch clauses.

可能需要启发式处理。寻找“泄露”到catch代码段之外的例外值。

“C++异常处理怎么用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


新闻标题:C++异常处理怎么用
文章网址:http://myzitong.com/article/ieeecj.html