龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > C/C++开发 >

丰富多彩的C++代码解析

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
下面着重讲述学习C++时碰到的相关难题和问题,以及学习C++的技巧,如何更好的进行C++代码解析,下文除了学习C++代码的基本编程技巧外还对C++代码的新特性进行全面研究。 所以 v 应该

下面着重讲述学习C++时碰到的相关难题和问题,以及学习C++的技巧,如何更好的进行C++代码解析,下文除了学习C++代码的基本编程技巧外还对C++代码的新特性进行全面研究。

所以 v 应该调用它们的析构函数。但是假设在这个调用期间,第二个 Widgets 的析构函数又抛出一个异常。现在有两个异常同时在活动中,对于C++代码解析来说这太多了。在非常巧合的条件下发生这样两个同时活动的异常,程序的执行会终止或者引发未定义行为。

在本例中,将引发未定义行为。与此相同,使用任何标准库容器(比如,list,set),任何 TR1中的容器,甚至是一个数组,都可能会引发未定义问题。并非必须是容器或数组才会陷入麻烦。程序夭折或未定义行为是析构函数引发异常的结果。

即使没有使用容器或数组也会如此。C++ 不喜欢引发异常的析构函数。 这比较容易理解,但是如果你的析构函数需要执行一个可能失败而抛出异常的操作,该怎么办呢?例如,假设你与一个数据库连接类一起C++代码解析

  1. class Widget {  
  2.  public:  
  3. ...  
  4. ~Widget() { ... } // assume this might emit an exception  
  5. };  
  6.  
  7. void doSomething()  
  8. {  
  9.  std::vector<Widget> v;  
  10.  ...  
  11. } // v is automatically destroyed here  

为了确保客户不会忘记调用 DBconnection 对象的 close,一个合理的主意是为 DBConnection 建立一个资源管理类,在它的析构函数中调用 close。这样的资源管理类将在以后的文章中探讨,但在这里,只要认为这样一个类的析构函数看起来像这样就足够了:

  1. class DBConn { // class to manage DBConnection  
  2.  public: // objects  
  3. ...  
  4. ~DBConn() // make sure database connections  
  5. { // are always closed  
  6.  db.close();  
  7. }  
  8.  private:  
  9. DBConnection db;  
  10. };   
  11.  
  12. 它允许客户像这样编程:  
  13.  
  14. {   
  15.  // open a block  
  16.  DBConn dbc(DBConnection::create()); // create DBConnection object  
  17.  // and turn it over to a DBConn  
  18.  // object to manage  
  19.  ... // use the DBConnection object  
  20.  // via the DBConn interface  
  21. } // at end of block, the DBConn  
  22. // object is destroyed, thus  
  23. // automatically calling close on  
  24. // the DBConnection object  

既然能成功地进行C++代码解析那就好了,但是如果这个调用导致了异常,DBConn 的析构函数将散播那个异常,也就是说,它将离开析构函数。这就产生了问题,因为析构函数抛出了一个烫手的山芋。

精彩图集

赞助商链接