Namespaces
Variants

std:: is_trivially_copyable

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
is_trivially_copyable
(C++11)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
定義先ヘッダ <type_traits>
template < class T >
struct is_trivially_copyable ;
(C++11以降)

std::is_trivially_copyable UnaryTypeTrait です。

T trivially copyable 型である場合、メンバ定数 value true に設定します。それ以外の型の場合、 value false となります。

std:: remove_all_extents_t < T > が不完全型であり、かつ(CV修飾された可能性のある) void でない場合、動作は未定義です。

プログラムが std::is_trivially_copyable または std::is_trivially_copyable_v に対する特殊化を追加する場合、動作は未定義です。

目次

テンプレートパラメータ

T - チェックする型

ヘルパー変数テンプレート

template < class T >
constexpr bool is_trivially_copyable_v = is_trivially_copyable < T > :: value ;
(C++17以降)

std:: integral_constant から継承

メンバ定数

value
[static]
true もし T がトリビアルコピー可能な型の場合、 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++オブジェクトです。

#include <type_traits>
struct A { int m; };
static_assert(std::is_trivially_copyable_v<A> == true);
struct B { B(B const&) {} };
static_assert(std::is_trivially_copyable_v<B> == false);
struct C { virtual void foo(); };
static_assert(std::is_trivially_copyable_v<C> == false);
struct D
{
    int m;
    D(D const&) = default; // -> trivially copyable
    D(int x) : m(x + 1) {}
};
static_assert(std::is_trivially_copyable_v<D> == true);
int main() {}

欠陥報告

以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。

DR 適用対象 公開時の動作 正しい動作
LWG 2015 C++11 T は境界が不明な不完全クラス型の
配列である可能性があった
この場合の動作は
未定義である

関連項目

(C++11) (deprecated in C++26)
型がトリビアルかどうかをチェックする
(クラステンプレート)