Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

"noexcept" vs "Throws: nothing" [closed]

While going through the last edits of the C++0x Working draft I found a lot of

  • removal of the keyword noexcept
  • addition of textual Throws: nothing at the same place

and vice versa. Just some examples:

  • replacement of noexcept against Throws: nothing: 20.6.4 Pointer safety [util.dynamic.safety] template<class T> T*undeclare_reachable(T*p);
  • addition of noexcept: 20.6.3.2. Pointer traits member functions [pointer.traits.functions]: static pointer pointer_trait<T*>::pointer_to(...) noexcept;

Questions here:

  • Is there a general rule/pattern, when we will find noexcept vs. Throws: nothing in the Std-Lib?
  • Should users derive a specific behavior by that given rule? I.e. when they should or should not add noexcept to their own functions?
like image 996
towi Avatar asked Apr 22 '11 14:04

towi


People also ask

What happens if a Noexcept function throws?

If you throw, your program terminates What happens if you throw from a noexcept function? Your program terminates, and may or may not unwind the stack. Terminating program isn't the nicest way to report an error to your user. You would be surprised that most of C++ code might throw.

Does Noexcept make code faster?

That noexcept keyword is tricky, but just know that if you use it, your coding world will spin faster.

Is Noexcept useful?

The primary use of noexcept is for generic algorithms, e.g., when resizing a std::vector<T> : for an efficient algorithm moving elements it is necessary to know ahead of time that none of the moves will throw. If moving elements might throw, elements need to be copied instead.

What is Noexcept false?

The noexcept specifier with a Boolean parameter. The noexcept specifier has an optional Boolean parameter. noexcept(true) is equivalent to noexcept , meaning the function is non-throwing. noexcept(false) means the function is potentially throwing.


1 Answers

In Madrid we were strongly influenced by N3279 which includes the following guidelines:

Adopted Guidelines

  • No library destructor should throw. They shall use the implicitly supplied (non- throwing) exception specification.

  • Each library function having a wide contract, that the LWG agree cannot throw, should be marked as unconditionally noexcept.

  • If a library swap function, move-constructor, or move-assignment operator is conditionally-wide (i.e. can be proven to not throw by applying the noexcept operator) then it should be marked as conditionally noexcept. No other function should use a conditional noexcept specification.

  • Library functions designed for compatibility with “C” code (such as the atomics facility), may be marked as unconditionally noexcept.

I would not interpret these guidelines as necessarily targeting a wider audience. This is mainly an admission that we do have backward compatibility concerns with adding noexcept. If we get it wrong, noexcept is easier to add than to remove in the next standard. So we attempted an application of noexcept that was both conservative and systematic.

like image 93
Howard Hinnant Avatar answered Nov 08 '22 03:11

Howard Hinnant