c++ - 如何正确使用 noexcept 运算符

标签 c++ c++11 noexcept

我已经实现了一个智能指针,它存储一个类型为 T 的对象,带有调用内部对象方法的代理函数:

template <class Function, class ...Args, class ...Params> 
inline bool call( Function (T::*function)(Args...) const, Params&& ...args ) const noexcept( noexcept( function ));

但是我发现了一个奇怪的问题——当一个std::exception在一个成员函数中产生时,程序终止了,即使在一个try block 中调用了代理函数。所以我的问题是:使用 noexcept 运算符是否正确,如果不是,在这种情况下我应该如何使用它?

最佳答案

根据 C++11 §5.3.7/1:

The noexcept operator determines whether the evaluation of its operand, which is an unevaluated operand (Clause 5), can throw an exception (15.1).

计算表达式 (function)不能抛出异常,所以 noexcept(function)评估为 true .请注意,这与评估表达式 (*function)(std::forward<Params>(args)...) 相同, noexcept((*function)(std::forward<Params>(args)...))肯定会评估为 false , 因为成员函数指针不合格 noexcept .

noexcept是对函数指针类型的限定,如 const .自函数指针类型call接受不是 noexcept -合格,复杂noexcept(noexcept(...))将始终评估为 noexcept(false) .

编辑:以下是不正确的,不可能纯粹基于 noexcept 进行重载函数指针的限定,因为“异常规范不被视为函数类型的一部分。” (§15.4/13)

如果你想要call成为noexcept当给出 noexcept -限定成员函数指针,需要提供重载call(R (T::*)() const noexcept, ...) .

关于c++ - 如何正确使用 noexcept 运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18150625/

相关文章:

c++ - 作为参数传递的数组的 sizeof 的奇怪行为

c++ - 从对象返回函数c++返回一个新对象

c++ - 复制构造函数中初始化列表中的 make_unique 是不使用 noexcept 说明符的良好目的吗?

c++ - d'tor 的函数尝试 block 是否应该允许处理抛出成员变量 d'tor?

c++ - 为不同的可执行文件名称制作参数

用于在 Windows 控制台中运行的游戏的 C++ 控件

C++构造函数调用

C++ shared_ptr 从派生方法返回这个

c++ - clang 和 g++ 在处理 const 对象时的差异

c++ - 如何在具有 copy-and-swap 习语的赋值运算符中使用 noexcept?