相关疑难解决方法(0)

从析构函数中抛出异常

大多数人都说永远不会从析构函数中抛出异常 - 这样做会导致未定义的行为.Stroustrup指出"向量析构函数显式地为每个元素调用析构函数.这意味着如果元素析构函数抛出,向量破坏失败......实际上没有好的方法来防止从析构函数抛出的异常,所以库如果元素析构函数抛出",则不保证"(来自附录E3.2).

这篇文章似乎另有说法 - 抛出析构函数或多或少都没问题.

所以我的问题是 - 如果从析构函数抛出会导致未定义的行为,那么如何处理析构函数期间发生的错误?

如果在清理操作期间发生错误,您是否只是忽略它?如果它是一个可能在堆栈中处理但在析构函数中不正确的错误,那么从析构函数中抛出异常是否有意义?

显然,这类错误很少见,但可能.

c++ destructor exception raii

246
推荐指数
10
解决办法
11万
查看次数

C++ 11 Exception的析构函数允许现在抛出?

任何想法为什么virtual~exception()throw()在C++ 98中,但virtual~exception()在C++ 11中?

什么是允许C++ 11投入类的析构函数的设计决策exception

这里:

C++ 98:

class exception {
public:
  exception () throw();
  exception (const exception&) throw();
  exception& operator= (const exception&) throw();
  virtual ~exception() throw();
  virtual const char* what() const throw();
}
Run Code Online (Sandbox Code Playgroud)

C++ 11:

class exception {
public:
  exception () noexcept;
  exception (const exception&) noexcept;
  exception& operator= (const exception&) noexcept;
  virtual ~exception();
  virtual const char* what() const noexcept;
}
Run Code Online (Sandbox Code Playgroud)

c++ destructor exception c++11 c++98

14
推荐指数
1
解决办法
2254
查看次数

标签 统计

c++ ×2

destructor ×2

exception ×2

c++11 ×1

c++98 ×1

raii ×1