std::is_trivially_copyable
| Определено в заголовочном файле <type_traits>
|
||
template< class T > struct is_trivially_copyable; |
(начиная с C++11) | |
std::is_trivially_copyable является UnaryTypeTrait.
Если T является тривиально копируемым типом, предоставляет константу-элемент value, равную true. Для любого другого типа value равна false.
Если std::remove_all_extents_t<T> является неполным типом и не (возможно, cv-квалифицированным) void, поведение не определено.
Поведение программы, добавляющей специализации для std::is_trivially_copyable или std::is_trivially_copyable_v (начиная с C++17) не определено.
Параметры шаблона
| T | — | тип для проверки |
Шаблон вспомогательной переменной
<tbody> </tbody> template< class T > inline constexpr bool is_trivially_copyable_v = is_trivially_copyable<T>::value; |
(начиная с C++17) | |
Унаследован от std::integral_constant
Константы элементы
value [static] |
true, если T является тривиально копируемым типом, false иначе (public static константа-элемент) |
Функции-элементы
operator bool |
преобразует объект в bool, возвращает value (public функция-элемент) |
operator() (C++14) |
возвращает value (public функция-элемент) |
Типы элементы
| Тип | Определение |
value_type
|
bool
|
type
|
std::integral_constant<bool, value>
|
Примечание
Объекты тривиально копируемых типов, которые не являются потенциально перекрывающимися подобъектами, являются единственными объектами C++, которые можно безопасно копировать с помощью std::memcpy или сериализовать в/из двоичных файлов с помощью std::ofstream::write() / std::ifstream::read().
Пример
#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; // -> тривиально копируемый
D(int x): m(x+1) {}
};
static_assert(std::is_trivially_copyable_v<D> == true);
int main() {}
Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 2015 | C++11 | T может быть массивом неполного классового типас неизвестной границей |
поведение в этом случае не определено |
Смотрите также
(C++11) |
проверяет, является ли тип тривиальным (шаблон класса) |