std::move_if_noexcept

From cppreference.com
< cpp‎ | utility
Utilities library
Defined in header <utility>
template < class T >
/* see below */ move_if_noexcept( T& x ) noexcept ;
(since C++11)
(constexpr since C++14)

std::move_if_noexcept

The return type of std::move_if_noexcept is:

Parameters

x - the object to be moved or copied

Return value

std::move(x) or x

Complexity

Constant.

Notes

This is used, for example, by std::vector::resize , which may have to allocate new storage and then move or copy elements from old storage to new storage. If an exception occurs during this operation, std::vector::resize undoes everything it did to this point, which is only possible if std::move_if_noexcept

Example

#include <iostream>
#include <utility>
 
struct Bad
{
    Bad() {}
    Bad(Bad&&) // may throw
    {
        std::cout << "Throwing move constructor called\n";
    }
    Bad(const Bad&) // may throw as well
    {
        std::cout << "Throwing copy constructor called\n";
    }
};
 
struct Good
{
    Good() {}
    Good(Good&&) noexcept // will NOT throw
    {
        std::cout << "Non-throwing move constructor called\n";
    }
    Good(const Good&) noexcept // will NOT throw
    {
        std::cout << "Non-throwing copy constructor called\n";
    }
};
 
int main()
{
    Good g;
    Bad b;
    [[maybe_unused]] Good g2 = std::move_if_noexcept(g);
    [[maybe_unused]] Bad b2 = std::move_if_noexcept(b);
}

Output:

Non-throwing move constructor called
Throwing copy constructor called

See also

(C++11)
forwards a function argument and use the type template argument to preserve its value category
(function template)
(C++11)
converts the argument to an xvalue
(function template)