std::is_trivially_copyable
來自 cppreference.com
定義於標頭檔案 <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
新增特化,則行為未定義。
目錄 |
[編輯] 模板引數
T | - | 要檢查的型別 |
[edit] 輔助變數模板
template< class T > constexpr bool is_trivially_copyable_v = is_trivially_copyable<T>::value; |
(C++17 起) | |
繼承自 std::integral_constant
成員常量
value [靜態] |
如果 T 是一個可平凡複製的型別,則為 true,否則為 false(public static 成員常量) |
成員函式
operator bool |
將物件轉換為 bool,返回 value (公開成員函式) |
operator() (C++14) |
返回 value (公開成員函式) |
成員型別
型別 | 定義 |
value_type
|
bool |
型別
|
std::integral_constant<bool, value> |
[edit] 註解
可平凡複製型別且非潛在重疊子物件的物件是唯一可在 C++ 中安全地透過 std::memcpy 複製,或透過 std::ofstream::write() / std::ifstream::read() 序列化到/從二進位制檔案讀寫的 C++ 物件。
[edit] 示例
執行此程式碼
#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() {}
[edit] 缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 2015 | C++11 | T 可以是不完整型別的陣列未知邊界的類型別 |
在這種情況下,行為是 未定義的 |
[edit] 參閱
(C++11)(C++26 中已棄用) |
檢查型別是否為平凡型別 (類模板) |