std::is_trivially_copyable
提供: cppreference.com
<tbody>
</tbody>
| ヘッダ <type_traits> で定義
|
||
template< class T > struct is_trivially_copyable; |
(C++11以上) | |
T が TriviallyCopyable な型であれば、 true に等しいメンバ定数 value が提供されます。 それ以外の型に対しては、 value は false です。
トリビアルにコピー可能な型は、スカラー型、トリビアルにコピー可能なクラス、およびそれらの配列だけです (cv 修飾されていても構いません)。
std::remove_all_extents_t<T> が不完全型であり、 void (または cv 修飾された void) でない場合、動作は未定義です。
テンプレート引数
| T | - | 調べる型 |
ヘルパー変数テンプレート
<tbody> </tbody> template< class T > inline constexpr bool is_trivially_copyable_v = is_trivially_copyable<T>::value; |
(C++17以上) | |
std::integral_constant から継承
メンバ定数
value [静的] |
T がトリビアルにコピー可能な型ならば true、そうでなければ false (パブリック静的メンバ定数) |
メンバ関数
operator bool |
オブジェクトを bool に変換します。 value を返します (パブリックメンバ関数) |
operator() (C++14) |
value を返します (パブリックメンバ関数) |
メンバ型
| 型 | 定義 |
value_type
|
bool
|
type
|
std::integral_constant<bool, value>
|
ノート
トリビアルにコピー可能な型は、 std::memcpy でコピーしたり、 std::ofstream::write() や std::ifstream::read() でバイナリファイルにシリアライズ、デシリアライズしても安全な C++ オブジェクトです。
一般的に、トリビアルにコピー可能な任意の型 T および T のオブジェクト obj1 について、 obj1 のベースとなるバイト列は、 char、 unsigned char または std::byte の配列に、または T の別のオブジェクト obj2 に、 (std::memcpy や std::memmove などの方法によって) コピーできます。 obj1 と obj2 はいずれも、潜在的にオーバーラップした部分オブジェクトであってはなりません。
obj1 のベースとなるバイト列がそのような配列にコピーされ、その後、結果の内容が obj1 にコピーし戻された場合、 obj1 は元の値を保持します。 obj1 のベースとなるバイト列が obj2 にコピーされた場合、 obj2 は obj1 の値を保持します。
例
Run this code
#include <iostream>
#include <type_traits>
struct A {
int m;
};
struct B {
B(B const&) {}
};
struct C {
virtual void foo();
};
struct D {
int m;
D(D const&) = default; // -> trivially copyable
D(int x): m(x+1) {}
};
int main()
{
std::cout << std::boolalpha;
std::cout << std::is_trivially_copyable<A>::value << '\n';
std::cout << std::is_trivially_copyable<B>::value << '\n';
std::cout << std::is_trivially_copyable<C>::value << '\n';
std::cout << std::is_trivially_copyable<D>::value << '\n';
}
出力:
true
false
false
true
関連項目
(C++11) |
型がトリビアルかどうか調べます (クラステンプレート) |