std::is_move_constructible, std::is_trivially_move_constructible, std::is_nothrow_move_constructible
From cppreference.com
| Defined in header <type_traits>
|
||
| template< class T > struct is_move_constructible; |
(1) | (since C++11) |
| template< class T > struct is_trivially_move_constructible; |
(2) | (since C++11) |
| template< class T > struct is_nothrow_move_constructible; |
(3) | (since C++11) |
1) Checks whether a type is MoveConstructible, that is, can be constructed from rvalue argument. If the requirement is met, a member constant value equal to true is provided; otherwise the value is false.
2) Same as 1), but the move constructor expression does not call any operation that is not trivial.
3) Same as 1), but the move constructor expression is noexcept.
Contents |
Inherited from std::integral_constant
Member constants
| value [static] |
true if T is move-constructible , false otherwise (public static member constant) |
Member functions
| operator bool |
converts the object to bool, returns value (public member function) |
Member types
| Type | Definition |
value_type
|
bool
|
type
|
std::integral_constant<bool, value> |
[edit] Notes
Types without a move constructor, but with a copy constructor that accepts const T& arguments, satisfy std::is_move_constructible.
Move constructors are usually noexcept, since otherwise they are unusable in any code that provides strong exception guarantee.
[edit] Possible implementation
template<class T> struct is_move_constructible : std::is_constructible<T, typename std::add_rvalue_reference<T>::type> {}; template<class T> struct is_trivially_move_constructible : std::is_trivially_constructible<T, typename std::add_rvalue_reference<T>::type> {}; template<class T> struct is_nothrow_move_constructible : std::is_nothrow_constructible<T, typename std::add_rvalue_reference<T>::type> {}; |
[edit] Example
Run this code
#include <iostream> #include <type_traits> struct Ex1 { std::string str; // member has a non-trivial but non-throwing move ctor }; struct Ex2 { int n; Ex2(Ex2&&) = default; // trivial and non-throwing }; int main() { std::cout << std::boolalpha << "Ex1 is move-constructible? " << std::is_move_constructible<Ex1>::value << '\n' << "Ex1 is trivially move-constructible? " << std::is_trivially_move_constructible<Ex1>::value << '\n' << "Ex1 is nothrow move-constructible? " << std::is_nothrow_move_constructible<Ex1>::value << '\n' << "Ex2 is trivially move-constructible? " << std::is_trivially_move_constructible<Ex2>::value << '\n' << "Ex2 is nothrow move-constructible? " << std::is_nothrow_move_constructible<Ex2>::value << '\n'; }
Output:
Ex1 is move-constructible? true Ex1 is trivially move-constructible? false Ex1 is nothrow move-constructible? true Ex2 is trivially move-constructible? true Ex2 is nothrow move-constructible? true
[edit] See also
| (C++11)(C++11)(C++11) |
checks if a type has a constructor for specific arguments (class template) |
| checks if a type has a default constructor (class template) | |
| (C++11)(C++11)(C++11) |
checks if a type has a copy constructor (class template) |
| (C++11) |
obtains an rvalue reference if the move constructor does not throw (function template) |