特性測試 (C++20起)
標準定義了一組預處理器宏,它們對應於C++11或更高版本中引入的C++語言和庫特性。它們旨在提供一種簡單且可移植的方式來檢測這些特性的存在。
目錄 |
[編輯] 屬性
__has_cpp_attribute( attribute-token ) |
|||||||||
檢查對由 attribute-token(宏展開後)命名的屬性的支援。
對於每個標準屬性,__has_cpp_attribute
展開為下表中給出的值(即該屬性新增到工作草案的年份和月份)或 0 是由實現定義的。當且僅當標準屬性導致實現按照建議行事(發出診斷訊息、影響類佈局等)時,它才會展開為表中的給定值。
特定於供應商的屬性的存在由非零值確定。
__has_cpp_attribute
可以在 #if 和 #elif 的表示式中展開。它被 #ifdef、 #ifndef、 #elifdef、 #elifndef(C++23起) 和 defined 視為已定義宏,但不能在其他地方使用。
attribute-token | 屬性 | 值 | 標準 | 提案 |
---|---|---|---|---|
assume
|
[[assume]]
|
202207L
|
(C++23) | P1774R8 |
carries_dependency
|
[[carries_dependency]]
|
200809L
|
(C++11) (直到 C++26) |
N2556 N2643 P3475R2 |
deprecated
|
[[deprecated]]
|
201309L
|
(C++14) | N3760 |
fallthrough
|
[[fallthrough]]
|
201603L
|
(C++17) | P0188R1 |
indeterminate
|
[[indeterminate]]
|
202403L
|
(C++26) | P2795R5 |
likely
|
[[likely]]
|
201803L
|
(C++20) | P0479R5 |
maybe_unused
|
[[maybe_unused]]
|
201603L
|
(C++17) | P0212R1 |
no_unique_address
|
[[no_unique_address]]
|
201803L
|
(C++20) | P0840R2 |
nodiscard
|
[[nodiscard]]
|
201603L
|
(C++17) | P0189R1 |
帶原因的[[nodiscard]] |
201907L
|
(C++20) | P1301R4 | |
noreturn
|
[[noreturn]]
|
200809L
|
(C++11) | N2761 |
unlikely
|
[[unlikely]]
|
201803L
|
(C++20) | P0479R5 |
屬性總數:11 |
[編輯] 語言特性
以下宏可用於檢測當前實現是否實現了某個語言特性。它們在每個翻譯單元中都是預定義的。
每個宏都展開為一個整數常量,對應於相關特性被包含在工作草案中的年份和月份。當特性發生重大變化時,宏將相應更新。
宏名稱 | 特性 | 值 | 標準 | 提案 |
---|---|---|---|---|
__cpp_aggregate_bases
|
帶基類的聚合類 | 201603L
|
(C++17) | P0017R1 |
__cpp_aggregate_nsdmi
|
帶預設成員初始化器的聚合類 | 201304L
|
(C++14) | N3653 |
__cpp_aggregate_paren_init
|
以直接初始化形式的聚合初始化 | 201902L
|
(C++20) | P0960R3 |
__cpp_alias_templates
|
別名模板 | 200704L
|
(C++11) | N2258 |
__cpp_aligned_new
|
過對齊資料的動態記憶體分配 | 201606L
|
(C++17) | P0035R4 |
__cpp_attributes
|
屬性 | 200809L
|
(C++11) | N2761 |
__cpp_auto_cast
|
auto(x) 和 auto{x} | 202110L
|
(C++23) | P0849R8 |
__cpp_binary_literals
|
二進位制字面量 | 201304L
|
(C++14) | N3472 |
__cpp_capture_star_this
|
將 *this 按值捕獲為 [=,*this] 的 Lambda 表示式 | 201603L
|
(C++17) | P0018R3 |
__cpp_char8_t
|
char8_t | 201811L
|
(C++20) | P0482R6 |
char8_t 相容性與可移植性修復(允許從 UTF-8 字串字面量初始化 (unsigned) char 陣列) | 202207L
|
(C++23) (DR20) |
P2513R4 | |
__cpp_concepts
|
概念 | 201907L
|
(C++20) | P0734R0 P1084R2 P1452R2 |
條件平凡特殊成員函式 | 202002L
|
P0848R3 P2493R0 | ||
__cpp_conditional_explicit
|
explicit(bool)
|
201806L
|
(C++20) | P0892R2 |
__cpp_consteval
|
即時函式 | 201811L
|
(C++20) | P1073R3 |
使 consteval 向上傳播 | 202211L
|
(C++23) (DR20) |
P2564R3 | |
__cpp_constexpr
|
constexpr | 200704L
|
(C++11) | N2235 |
寬鬆的 constexpr,非 const constexpr 方法 |
201304L
|
(C++14) | N3652 | |
Constexpr lambda | 201603L
|
(C++17) | P0170R1 | |
常數表示式中的虛擬函式呼叫;constexpr 函式中的try 塊,常數表示式中的dynamic_cast 和多型 typeid;constexpr 函式中的平凡預設初始化和asm 宣告 |
201907L
|
(C++20) | P1064R0 P1002R1 P1327R1 P1331R2 P1668R1 | |
在常數求值中改變聯合體的活動成員 | 202002L
|
P1330R0 P2493R0 | ||
constexpr 函式中的非字面量變數、標籤和goto 語句 | 202110L
|
(C++23) | P2242R3 | |
放寬對 constexpr 函式和函式模板的一些限制 | 202207L
|
P2448R2 | ||
允許在 constexpr 函式中使用靜態 constexpr 變數 | 202211L
|
P2647R1 | ||
從 void* 進行 constexpr 轉換:走向 constexpr 型別擦除 | 202306L
|
(C++26) | P2738R1 | |
constexpr placement new | 202406L
|
P2747R2 | ||
__cpp_constexpr_dynamic_alloc
|
constexpr 函式中的動態儲存持續時間操作 | 201907L
|
(C++20) | P0784R7 |
__cpp_constexpr_exceptions
|
constexpr 異常 | 202411L
|
(C++26) | P3068R6 |
__cpp_constexpr_in_decltype
|
當常數求值所需時生成函式和變數定義 | 201711L
|
(C++20) (DR11) |
P0859R0 |
__cpp_constinit
|
constinit | 201907L
|
(C++20) | P1143R2 |
__cpp_contracts
|
契約 | 202502L
|
(C++26) | P2900R14 |
__cpp_decltype
|
decltype | 200707L
|
(C++11) | N2343 |
__cpp_decltype_auto
|
普通函式的返回型別推導 | 201304L
|
(C++14) | N3638 |
__cpp_deduction_guides
|
類模板的模板引數推導(CTAD) | 201703L
|
(C++17) | P0091R3 P0512R0 P0620R0 |
聚合和別名的 CTAD | 201907L
|
(C++20) | P1814R0 P1816R0 | |
__cpp_delegating_constructors
|
委託建構函式 | 200604L
|
(C++11) | N1986 |
__cpp_deleted_function
|
帶訊息的刪除函式定義(= delete("應有理由");) | 202403L
|
(C++26) | P2573R2 |
__cpp_designated_initializers
|
指定初始化器 | 201707L
|
(C++20) | P0329R4 |
__cpp_enumerator_attributes
|
列舉器的屬性 | 201411L
|
(C++17) | N4266 |
__cpp_explicit_this_parameter
|
顯式物件引數 | 202110L
|
(C++23) | P0847R7 |
__cpp_fold_expressions
|
摺疊表示式 | 201603L
|
(C++17) | N4295 P0036R0 |
涉及摺疊表示式的約束的順序 | 202406L
|
(C++26) | P2963R3 | |
__cpp_generic_lambdas
|
泛型 lambda 表示式 | 201304L
|
(C++14) | N3649 |
泛型 lambda 的顯式模板引數列表 | 201707L
|
(C++20) | P0428R2 | |
__cpp_guaranteed_copy_elision
|
透過簡化的值類別保證的複製省略 | 201606L
|
(C++17) | P0135R1 |
__cpp_hex_float
|
十六進位制浮點字面量 | 201603L
|
(C++17) | P0245R1 |
__cpp_if_consteval
|
if consteval
|
202106L
|
(C++23) | P1938R3 |
__cpp_if_constexpr
|
if constexpr
|
201606L
|
(C++17) | P0292R2 |
__cpp_impl_coroutine
|
協程(編譯器支援) | 201902L
|
(C++20) | P0912R5 LWG3393 |
__cpp_impl_destroying_delete
|
銷燬 operator delete (編譯器支援) |
201806L
|
(C++20) | P0722R3 |
__cpp_impl_three_way_comparison
|
三向比較(編譯器支援) | 201907L
|
(C++20) | P0515R3 P0768R1 P1185R2 P1630R1 |
__cpp_implicit_move
|
更簡單的隱式移動 | 202207L
|
(C++23) | P2266R3 |
__cpp_inheriting_constructors
|
繼承建構函式 | 200802L
|
(C++11) | N2540 |
重新措辭繼承建構函式:繼承建構函式的新規範(DR1941 等) | 201511L
|
(C++17) (DR11) |
P0136R1 | |
__cpp_init_captures
|
Lambda 初始化捕獲 | 201304L
|
(C++14) | N3648 |
允許在 lambda 初始化捕獲中進行包展開 | 201803L
|
(C++20) | P0780R2 | |
__cpp_initializer_lists
|
列表初始化和 std::initializer_list | 200806L
|
(C++11) | N2672 |
__cpp_inline_variables
|
內聯變數 | 201606L
|
(C++17) | P0386R2 |
__cpp_lambdas
|
Lambda 表示式 | 200907L
|
(C++11) | N2927 |
__cpp_modules
|
模組 | 201907L
|
(C++20) | P1103R3 P1811R0 |
__cpp_multidimensional_subscript
|
多維下標運算子 | 202110L
|
(C++23) | P2128R6 |
靜態operator[] | 202211L
|
P2589R1 | ||
__cpp_named_character_escapes
|
命名的通用字元轉義序列 | 202207L
|
(C++23) | P2071R2 |
__cpp_namespace_attributes
|
名稱空間的屬性 | 201411L
|
(C++17) | N4266 |
__cpp_noexcept_function_type
|
使異常規範成為型別系統的一部分 | 201510L
|
(C++17) | P0012R1 |
__cpp_nontype_template_args
|
允許對所有非型別模板引數進行常量求值 | 201411L
|
(C++17) | N4268 |
非型別模板引數中的類型別和浮點型別 | 201911L
|
(C++20) | P1907R1 | |
__cpp_nontype_template_parameter_auto
|
用 auto 宣告非型別模板引數 | 201606L
|
(C++17) | P0127R2 |
__cpp_nsdmi
|
非靜態資料成員初始化器 | 200809L
|
(C++11) | N2756 |
__cpp_pack_indexing
|
包索引 | 202311L
|
(C++26) | P2662R3 |
__cpp_placeholder_variables
|
一個沒有名字的漂亮佔位符 | 202306L
|
(C++26) | P2169R4 |
__cpp_pp_embed
|
#embed | 202502L
|
(C++26) | P1967R14 |
__cpp_range_based_for
|
基於範圍的 for 迴圈
|
200907L
|
(C++11) | N2930 |
帶不同 begin /end 型別的基於範圍的 for 迴圈 |
201603L
|
(C++17) | P0184R0 | |
基於範圍的 for 中的生命週期延長 | 202211L
|
(C++23) | P2644R1 P2718R0 CWG2659 | |
__cpp_raw_strings
|
原始字串字面量 | 200710L
|
(C++11) | N2442 |
__cpp_ref_qualifiers
|
ref-限定符 | 200710L
|
(C++11) | N2439 |
__cpp_return_type_deduction
|
普通函式的返回型別推導 | 201304L
|
(C++14) | N3638 |
__cpp_rvalue_references
|
右值引用 | 200610L
|
(C++11) | N2118 |
__cpp_size_t_suffix
|
std::size_t 及其有符號版本的字面量字尾
|
202011L
|
(C++23) | P0330R8 |
__cpp_sized_deallocation
|
大小確定的解分配 | 201309L
|
(C++14) | N3778 |
__cpp_static_assert
|
static_assert | 200410L
|
(C++11) | N1720 |
單引數 static_assert
|
201411L
|
(C++17) | N3928 | |
使用者生成的 static_assert 訊息
|
202306L
|
(C++26) | P2741R3 | |
__cpp_static_call_operator
|
靜態operator() | 202207L
|
(C++23) | P1169R4 |
__cpp_structured_bindings
|
結構化繫結 | 201606L
|
(C++17) | P0217R3 |
結構化繫結的屬性 | 202403L
|
(C++26) | P0609R3 | |
結構化繫結宣告作為條件 | 202406L
|
P0963R3 | ||
結構化繫結可以引入一個包 | 202411L
|
P1061R10 | ||
__cpp_template_parameters
|
概念和變數模板的模板引數 | 202502L
|
(C++26) | P2841R7 |
__cpp_template_template_args
|
模板模板引數的匹配 | 201611L
|
(C++17) | P0522R0 |
__cpp_threadsafe_static_init
|
帶併發的動態初始化和銷燬 | 200806L
|
(C++11) | N2660 |
__cpp_trivial_relocatability
|
平凡可重定位性 | 202502L
|
(C++26) | P2786R13 |
__cpp_trivial_union
|
平凡聯合 | 202502L
|
(C++26) | P3074R7 |
__cpp_unicode_characters
|
新字元型別(char16_t 和 char32_t) | 200704L
|
(C++11) | N2249 |
__cpp_unicode_literals
|
Unicode 字串字面量 | 200710L
|
(C++11) | N2442 |
__cpp_user_defined_literals
|
使用者定義字面量 | 200809L
|
(C++11) | N2765 |
__cpp_using_enum
|
using enum | 201907L
|
(C++20) | P1099R5 |
__cpp_variable_templates
|
變數模板 | 201304L
|
(C++14) | N3651 |
__cpp_variadic_friend
|
可變引數友元宣告 | 202403L
|
(C++26) | P2893R3 |
__cpp_variadic_templates
|
可變引數模板 | 200704L
|
(C++11) | N2242 |
__cpp_variadic_using
|
using -宣告中的包展開 |
201611L
|
(C++17) | P0195R2 |
宏總數:76 |
[編輯] 庫特性
以下宏可用於檢測當前實現是否實現了標準庫特性。與語言特性測試宏不同,它們不是預定義的。相反,它們由標頭檔案 <version> 提供。
對於每個庫特性測試宏,提供相關標準庫元件的標頭檔案也會提供它。有關提供這些宏的標頭檔案的完整列表,請參閱庫特性測試宏。
每個宏都展開為一個整數常量,對應於相關特性被包含在工作草案中的年份和月份。當特性發生重大變化時,宏將相應更新。
宏名稱 | 特性 | 值 | 標準 | 提案 |
---|---|---|---|---|
__cpp_lib_adaptor_iterator_pair_constructor
|
std::stack 和 std::queue 的迭代器對建構函式 | 202106L
|
(C++23) | P1425R4 |
__cpp_lib_addressof_constexpr
|
Constexpr std::addressof | 201603L
|
(C++17) | LWG2296 |
__cpp_lib_algorithm_default_value_type
|
為演算法啟用列表初始化 | 202403L
|
(C++26) | P2248R8 P3217R0 |
__cpp_lib_algorithm_iterator_requirements
|
Ranges 迭代器作為非 Ranges 演算法的輸入 | 202207L
|
(C++23) | P2408R5 |
__cpp_lib_aligned_accessor
|
std::aligned_accessor:表示指標過對齊的 std::mdspan 訪問器 | 202411L
|
(C++26) | P2897R7 |
__cpp_lib_allocate_at_least
|
分配器介面中的大小反饋,例如:std::allocator::allocate_at_least,std::allocator_traits::allocate_at_least | 202302L
|
(C++23) | P0401R6 P2652R2 LWG3887 |
__cpp_lib_allocator_traits_is_always_equal
|
std::allocator_traits::is_always_equal,noexcept 清理 | 201411L
|
(C++17) | N4258 |
__cpp_lib_any
|
std::any | 201606L
|
(C++17) | P0220R1 P0032R3 |
__cpp_lib_apply
|
std::apply | 201603L
|
(C++17) | P0220R1 |
__cpp_lib_array_constexpr
|
std::reverse_iterator、std::move_iterator、std::array 和範圍訪問的 constexpr | 201603L
|
(C++17) | P0031R0 |
ConstexprIterator;constexpr std::array 的比較;雜項 constexpr 位(std::array::fill 等) | 201811L
|
(C++20) | P0858R0 LWG3257 P1023R0 P1032R1 | |
__cpp_lib_as_const
|
std::as_const | 201510L
|
(C++17) | P0007R1 |
__cpp_lib_associative_heterogeneous_erasure
|
關聯容器和無序關聯容器中的異構擦除 | 202110L
|
(C++23) | P2077R3 |
__cpp_lib_associative_heterogeneous_insertion
|
有序和無序關聯容器中剩餘成員函式的異構過載 | 202306L
|
(C++26) | P2363R5 |
__cpp_lib_assume_aligned
|
std::assume_aligned | 201811L
|
(C++20) | P1007R3 |
__cpp_lib_atomic_flag_test
|
std::atomic_flag::test | 201907L
|
(C++20) | P1135R6 |
__cpp_lib_atomic_float
|
浮點原子操作 | 201711L
|
(C++20) | P0020R6 |
__cpp_lib_atomic_is_always_lock_free
|
Constexpr std::atomic<T>::is_always_lock_free | 201603L
|
(C++17) | P0152R1 |
__cpp_lib_atomic_lock_free_type_aliases
|
原子無鎖整數型別(std::atomic_signed_lock_free, std::atomic_unsigned_lock_free) | 201907L
|
(C++20) | P1135R6 |
__cpp_lib_atomic_min_max
|
原子最小值/最大值(std::atomic::fetch_min, std::atomic::fetch_max 等) | 202403L
|
(C++26) | P0493R5 |
__cpp_lib_atomic_ref
|
std::atomic_ref | 201806L
|
(C++20) | P0019R8 |
std::atomic_ref::address() | 202411L
|
(C++26) | P2835R7 | |
__cpp_lib_atomic_shared_ptr
|
std::atomic<std::shared_ptr> | 201711L
|
(C++20) | P0718R2 |
__cpp_lib_atomic_value_initialization
|
修復原子初始化(預設值初始化 std::atomic) | 201911L
|
(C++20) | P0883R2 |
__cpp_lib_atomic_wait
|
高效的 std::atomic 等待 | 201907L
|
(C++20) | P1135R6 |
__cpp_lib_barrier
|
std::barrier | 201907L
|
(C++20) | P1135R6 |
std::barrier 的階段完成保證 | 202302L
|
(C++23) | P2588R3 | |
__cpp_lib_bind_back
|
std::bind_back | 202202L
|
(C++23) | P2387R3 |
允許將可呼叫物件作為非型別模板引數傳遞給 std::bind_back | 202306L
|
(C++26) | P2714R1 | |
__cpp_lib_bind_front
|
std::bind_front | 201907L
|
(C++20) | P0356R5 P1651R0 |
允許將可呼叫物件作為非型別模板引數傳遞給 std::bind_front | 202306L
|
(C++26) | P2714R1 | |
__cpp_lib_bit_cast
|
std::bit_cast | 201806L
|
(C++20) | P0476R2 |
__cpp_lib_bitops
|
位操作 | 201907L
|
(C++20) | P0553R4 |
__cpp_lib_bitset
|
std::bitset 與 std::string_view 的介面 | 202306L
|
(C++26) | P2697R1 |
__cpp_lib_bool_constant
|
std::bool_constant | 201505L
|
(C++17) | N4389 |
__cpp_lib_bounded_array_traits
|
std::is_bounded_array, std::is_unbounded_array | 201902L
|
(C++20) | P1357R1 |
__cpp_lib_boyer_moore_searcher
|
搜尋器 | 201603L
|
(C++17) | P0220R1 |
__cpp_lib_byte
|
std::byte | 201603L
|
(C++17) | P0298R3 |
__cpp_lib_byteswap
|
std::byteswap | 202110L
|
(C++23) | P1272R4 |
__cpp_lib_char8_t
|
對 char8_t 的庫支援 |
201907L
|
(C++20) | P0482R6 P1423R3 |
__cpp_lib_chrono
|
std::chrono::duration 和 std::chrono::time_point 的舍入函式 | 201510L
|
(C++17) | P0092R1 |
std::chrono::duration 和 std::chrono::time_point 所有成員函式的 constexpr | 201611L
|
P0505R0 | ||
日曆和時區 | 201907L
|
(C++20) | P0355R7 P1466R3 | |
std::chrono 值類的雜湊支援 | 202306L
|
(C++26) | P2592R3 | |
__cpp_lib_chrono_udls
|
時間型別的使用者定義字面量 | 201304L
|
(C++14) | N3642 |
__cpp_lib_clamp
|
std::clamp | 201603L
|
(C++17) | P0025R1 |
__cpp_lib_common_reference
|
將 std::reference_wrapper 的 std::common_reference_t 設為引用型別 | 202302L
|
(C++23) | P2655R3 |
__cpp_lib_common_reference_wrapper
|
將 std::reference_wrapper 的 std::common_reference_t 設為引用型別 | 202302L
|
(C++23) | P2655R3 |
__cpp_lib_complex_udls
|
std::complex 的使用者定義字面量
|
201309L
|
(C++14) | N3779 |
__cpp_lib_concepts
|
標準庫概念 | 202002L
|
(C++20) | P0898R3 P1754R1 P1964R2 |
equality_comparable_with 、totally_ordered_with 和 three_way_comparable_with 的僅可移動型別 |
202207L
|
(C++23) | P2404R3 | |
__cpp_lib_constexpr_algorithms
|
演算法的 Constexpr | 201806L
|
(C++20) | P0202R3 P0879R0 LWG3256 LWG3792 |
Constexpr 穩定排序 | 202306L
|
(C++26) | P2562R1 | |
__cpp_lib_constexpr_atomic
|
constexpr std::atomic 和 std::atomic_ref | 202411L
|
(C++26) | P3309R3 |
__cpp_lib_constexpr_bitset
|
一個更 constexpr 的 std::bitset | 202207L
|
(C++23) | P2417R2 |
__cpp_lib_constexpr_charconv
|
整數型別的 std::to_chars 和 std::from_chars 的 Constexpr | 202207L
|
(C++23) | P2291R3 |
__cpp_lib_constexpr_cmath
|
<cmath> 和 <cstdlib> 中數學函式的 Constexpr | 202202L
|
(C++23) | P0533R9 |
<cmath> 的更多 constexpr | 202306L
|
(C++26) | P1383R2 | |
__cpp_lib_constexpr_complex
|
std::complex 的 Constexpr | 201711L
|
(C++20) | P0415R1 |
<complex> 的更多 constexpr | 202306L
|
(C++26) | P1383R2 | |
__cpp_lib_constexpr_containers
|
更多 constexpr 容器和介面卡 | 202502L
|
(C++26) | P3372R2 |
__cpp_lib_constexpr_dynamic_alloc
|
std::allocator 和相關工具的 Constexpr | 201907L
|
(C++20) | P0784R7 |
__cpp_lib_constexpr_exceptions
|
異常型別的 constexpr,例如 std::bad_alloc,std::bad_cast 等 | 202411L
|
(C++26) | P3068R6 |
異常型別的更多 constexpr | 202502L
|
P3378R2 | ||
__cpp_lib_constexpr_functional
|
雜項 constexpr 位(std::default_searcher);constexpr INVOKE |
201907L
|
(C++20) | P1032R1 P1065R2 |
__cpp_lib_constexpr_inplace_vector
|
非平凡型別的 constexpr std::inplace_vector | 202502L
|
(C++26) | P3074R7 |
__cpp_lib_constexpr_iterator
|
雜項 constexpr 位(std::insert_iterator 等) | 201811L
|
(C++20) | P1032R1 |
__cpp_lib_constexpr_memory
|
std::pointer_traits 中的 Constexpr | 201811L
|
(C++20) | P1006R1 |
Constexpr std::unique_ptr | 202202L
|
(C++23) | P2273R3 | |
__cpp_lib_constexpr_new
|
Placement new 的 Constexpr | 202406L
|
(C++26) | P2747R2 |
__cpp_lib_constexpr_numeric
|
<numeric> 中演算法的 Constexpr | 201911L
|
(C++20) | P1645R1 |
__cpp_lib_constexpr_string
|
constexpr std::char_traits | 201611L
|
(C++17) | P0426R1 |
constexpr std::string | 201907L
|
(C++20) | P0980R1 | |
__cpp_lib_constexpr_string_view
|
雜項 constexpr 位(std::string_view::copy) | 201811L
|
(C++20) | P1032R1 |
__cpp_lib_constexpr_tuple
|
雜項 constexpr 位(std::tuple::operator= 等) | 201811L
|
(C++20) | P1032R1 |
__cpp_lib_constexpr_typeinfo
|
std::type_info::operator== 的 Constexpr | 202106L
|
(C++23) | P1328R1 |
__cpp_lib_constexpr_utility
|
雜項 constexpr 位(std::pair::operator= 等) | 201811L
|
(C++20) | P1032R1 |
__cpp_lib_constexpr_vector
|
std::vector 的 Constexpr | 201907L
|
(C++20) | P1004R2 |
__cpp_lib_constrained_equality
|
std::pair、std::tuple、std::optional 和 std::variant 的受限關係運算符 | 202403L
|
(C++26) | P2944R3 |
限制 std::expected 相等運算子 | 202411L
|
P3379R0 | ||
__cpp_lib_containers_ranges
|
容器和字串的範圍感知構造和插入 | 202202L
|
(C++23) | P1206R7 |
__cpp_lib_contracts
|
<contracts>:契約支援 | 202502L
|
(C++26) | P2900R14 |
__cpp_lib_copyable_function
|
std::copyable_function | 202306L
|
(C++26) | P2548R6 |
__cpp_lib_coroutine
|
協程(庫支援) | 201902L
|
(C++20) | P0912R5 LWG3393 |
__cpp_lib_debugging
|
<debugging>:除錯支援 | 202311L
|
(C++26) | P2546R5 |
可替換的 std::is_debugger_present | 202403L
|
P2810R4 | ||
__cpp_lib_destroying_delete
|
銷燬 operator delete(庫支援) | 201806L
|
(C++20) | P0722R3 |
__cpp_lib_enable_shared_from_this
|
std::enable_shared_from_this::weak_from_this | 201603L
|
(C++17) | P0033R1 |
__cpp_lib_endian
|
std::endian | 201907L
|
(C++20) | P0463R1 P1612R1 |
__cpp_lib_erase_if
|
統一容器擦除 | 202002L
|
(C++20) | P1209R0 P1115R3 |
__cpp_lib_exchange_function
|
std::exchange | 201304L
|
(C++14) | N3668 |
__cpp_lib_execution
|
執行策略 | 201603L
|
(C++17) | P0024R2 |
std::execution::unsequenced_policy | 201902L
|
(C++20) | P1001R2 | |
__cpp_lib_expected
|
類模板 std::expected | 202202L
|
(C++23) | P0323R12 |
std::expected 的單子函式 | 202211L
|
P2505R5 | ||
__cpp_lib_filesystem
|
檔案系統庫 | 201703L
|
(C++17) | P0218R1 P0219R1 P0392R0 P0317R1 |
__cpp_lib_flat_map
|
std::flat_map 和 std::flat_multimap | 202207L
|
(C++23) | P0429R9 |
__cpp_lib_flat_set
|
std::flat_set 和 std::flat_multiset | 202207L
|
(C++23) | P1222R4 LWG3751 |
__cpp_lib_format
|
文字格式化 | 201907L
|
(C++20) | P0645R10 P1361R2 P1652R1 |
編譯時格式字串檢查;減少 std::vformat_to 的引數化 | 202106L
|
(C++23) (DR20) |
P2216R3 | |
修復 chrono 格式化器中的區域設定處理;支援不可 const 格式化的型別 | 202110L
|
P2372R3 P2418R2 | ||
暴露 std::basic_format_string;澄清 chrono 型別本地化格式化中編碼的處理 | 202207L
|
(C++23) | P2419R2 P2508R1 | |
格式化指標 | 202304L
|
(C++26) | P2510R3 | |
型別檢查格式引數 | 202305L
|
P2757R3 | ||
成員 visit | 202306L
|
P2637R3 | ||
執行時格式字串 | 202311L
|
P2918R2 | ||
__cpp_lib_format_path
|
std::filesystem::path 的格式化 | 202403L
|
(C++26) | P2845R8 |
__cpp_lib_format_ranges
|
格式化範圍 | 202207L
|
(C++23) | P2286R8 P2585R1 LWG3750 |
__cpp_lib_format_uchar
|
修復程式碼單元作為整數的格式化 | 202311L
|
(C++26) | P2909R4 |
__cpp_lib_formatters
|
格式化 std::thread::id 和 std::stacktrace | 202302L
|
(C++23) | P2693R1 |
__cpp_lib_forward_like
|
std::forward_like | 202207L
|
(C++23) | P2445R1 |
__cpp_lib_freestanding_algorithm
|
<algorithm> 中的獨立設施 | 202311L
|
(C++26) | P2407R5 |
__cpp_lib_freestanding_array
|
使 std::array 的部分功能獨立 | 202311L
|
(C++26) | P2407R5 |
__cpp_lib_freestanding_char_traits
|
獨立 std::char_traits | 202306L
|
(C++26) | P2338R4 |
__cpp_lib_freestanding_charconv
|
<charconv> 中的獨立設施 | 202306L
|
(C++26) | P2338R4 |
__cpp_lib_freestanding_cstdlib
|
<cstdlib> 中的獨立設施 | 202306L
|
(C++26) | P2338R4 |
__cpp_lib_freestanding_cstring
|
<cstring> 中的獨立設施 | 202306L
|
(C++26) | P2338R4 |
從獨立設施中移除 std::strtok | 202311L
|
P2937R0 | ||
__cpp_lib_freestanding_cwchar
|
<cwchar> 中的獨立設施 | 202306L
|
(C++26) | P2338R4 |
__cpp_lib_freestanding_errc
|
獨立 std::errc | 202306L
|
(C++26) | P2338R4 |
__cpp_lib_freestanding_expected
|
使 std::expected 的部分功能獨立 | 202311L
|
(C++26) | P2833R2 |
__cpp_lib_freestanding_feature_test_macros
|
獨立特性測試宏的支援 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_functional
|
<functional> 中的獨立設施 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_iterator
|
<iterator> 中的獨立設施 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_mdspan
|
獨立 std::mdspan | 202311L
|
(C++26) | P2833R2 |
__cpp_lib_freestanding_memory
|
<memory> 中的獨立設施 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_numeric
|
<numeric> 中的獨立設施(飽和算術) | 202311L
|
(C++26) | P0543R3 |
__cpp_lib_freestanding_operator_new
|
operator new 的定義(在獨立實現中可選) | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_optional
|
使 std::optional 的部分功能獨立 | 202311L
|
(C++26) | P2407R5 |
__cpp_lib_freestanding_ranges
|
<ranges> 中的獨立設施 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_ratio
|
<ratio> 中的獨立設施 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_string_view
|
使 std::string_view 的部分功能獨立 | 202311L
|
(C++26) | P2407R5 |
__cpp_lib_freestanding_tuple
|
<tuple> 中的獨立設施 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_utility
|
<utility> 中的獨立設施 | 202306L
|
(C++26) | P2198R7 |
__cpp_lib_freestanding_variant
|
使 std::variant 的部分功能獨立 | 202311L
|
(C++26) | P2407R5 |
__cpp_lib_fstream_native_handle
|
從檔案流獲取原生控制代碼 | 202306L
|
(C++26) | P1759R6 |
__cpp_lib_function_ref
|
std::function_ref:型別擦除的可呼叫引用 | 202306L
|
(C++26) | P0792R14 |
__cpp_lib_gcd_lcm
|
std::gcd, std::lcm | 201606L
|
(C++17) | P0295R0 |
__cpp_lib_generator
|
std::generator:範圍的同步協程生成器 | 202207L
|
(C++23) | P2502R2 |
__cpp_lib_generic_associative_lookup
|
關聯容器中的異構比較查詢 | 201304L
|
(C++14) | N3657 |
__cpp_lib_generic_unordered_lookup
|
無序關聯容器中的異構比較查詢 | 201811L
|
(C++20) | P0919R3 |
__cpp_lib_hardware_interference_size
|
Constexpr std::hardware_{constructive, destructive}_interference_size | 201703L
|
(C++17) | P0154R1 |
__cpp_lib_hive
|
<hive>:一個基於桶的容器,重新使用已擦除元素的記憶體位置 | 202502L
|
(C++26) | P0447R28 |
__cpp_lib_has_unique_object_representations
|
std::has_unique_object_representations | 201606L
|
(C++17) | P0258R2 |
__cpp_lib_hazard_pointer
|
<hazard_pointer>:危險指標 | 202306L
|
(C++26) | P2530R3 |
__cpp_lib_hypot
|
std::hypot 的 3 引數過載 | 201603L
|
(C++17) | P0030R1 |
__cpp_lib_incomplete_container_elements
|
std::forward_list、std::list 和 std::vector 的最小不完整型別支援 | 201505L
|
(C++17) | N4510 |
__cpp_lib_indirect
|
std::indirect | 202502L
|
(C++26) | P3019R13 |
__cpp_lib_inplace_vector
|
std::inplace_vector:具有固定容量(原地儲存)的動態大小可變向量 | 202406L
|
(C++26) | P0843R14 |
__cpp_lib_int_pow2
|
整數 2 的冪運算(std::has_single_bit、std::bit_ceil、std::bit_floor、std::bit_width) | 202002L
|
(C++20) | P0556R3 P1956R1 |
__cpp_lib_integer_comparison_functions
|
整數比較函式 | 202002L
|
(C++20) | P0586R2 |
__cpp_lib_integer_sequence
|
編譯時整數序列 | 201304L
|
(C++14) | N3658 |
__cpp_lib_integral_constant_callable
|
std::integral_constant::operator() | 201304L
|
(C++14) | N3545 |
__cpp_lib_interpolate
|
std::lerp, std::midpoint | 201902L
|
(C++20) | P0811R3 |
__cpp_lib_invoke
|
std::invoke | 201411L
|
(C++17) | N4169 |
__cpp_lib_invoke_r
|
std::invoke_r | 202106L
|
(C++23) | P2136R3 |
__cpp_lib_ios_noreplace
|
支援 fstream 的獨佔模式 | 202207L
|
(C++23) | P2467R1 |
__cpp_lib_is_aggregate
|
std::is_aggregate | 201703L
|
(C++17) | LWG2911 |
__cpp_lib_is_constant_evaluated
|
std::is_constant_evaluated | 201811L
|
(C++20) | P0595R2 |
__cpp_lib_is_final
|
std::is_final | 201402L
|
(C++14) | LWG2112 |
__cpp_lib_is_implicit_lifetime
|
std::is_implicit_lifetime | 202302L
|
(C++23) | P2674R1 |
__cpp_lib_is_invocable
|
std::is_invocable, std::invoke_result | 201703L
|
(C++17) | P0604R0 |
__cpp_lib_is_layout_compatible
|
std::is_layout_compatible | 201907L
|
(C++20) | P0466R5 |
__cpp_lib_is_nothrow_convertible
|
std::is_convertible | 201806L
|
(C++20) | P0758R1 LWG3356 |
__cpp_lib_is_null_pointer
|
std::is_null_pointer | 201309L
|
(C++14) (DR11) |
LWG2247 |
__cpp_lib_is_pointer_interconvertible
|
指標互可轉換性特性:std::is_pointer_interconvertible_with_class, std::is_pointer_interconvertible_base_of | 201907L
|
(C++20) | P0466R5 |
__cpp_lib_is_scoped_enum
|
std::is_scoped_enum | 202011L
|
(C++23) | P1048R1 |
__cpp_lib_is_sufficiently_aligned
|
std::is_sufficiently_aligned:檢查指標的對齊前置條件 | 202411L
|
(C++26) | P2897R7 |
__cpp_lib_is_swappable
|
(nothrow-)swappable 特性 | 201603L
|
(C++17) | P0185R1 |
__cpp_lib_is_virtual_base_of
|
std::is_virtual_base_of:檢測虛基類的型別特性 | 202406L
|
(C++26) | P2985R0 |
__cpp_lib_is_within_lifetime
|
檢查聯合體的替代項是否活躍(std::is_within_lifetime) | 202306L
|
(C++26) | P2641R4 |
__cpp_lib_jthread
|
停止令牌和可加入執行緒 | 201911L
|
(C++20) | P0660R10 P1869R1 |
__cpp_lib_latch
|
std::latch | 201907L
|
(C++20) | P1135R6 |
__cpp_lib_launder
|
CWG 問題 1776:包含引用成員的類物件的替換(std::launder) | 201606L
|
(C++17) | P0137R1 |
__cpp_lib_linalg
|
基於 BLAS 的自由函式線性代數介面 | 202311L
|
(C++26) | P1673R13 |
__cpp_lib_list_remove_return_type
|
更改 std::forward_list 和 std::list 的 remove() 、remove_if() 和 unique() 的返回型別 |
201806L
|
(C++20) | P0646R1 |
__cpp_lib_logical_traits
|
型別特性上的邏輯運算 | 201510L
|
(C++17) | P0013R1 |
__cpp_lib_make_from_tuple
|
std::make_from_tuple | 201606L
|
(C++17) | P0209R2 |
__cpp_lib_make_reverse_iterator
|
std::make_reverse_iterator | 201402L
|
(C++14) | LWG2285 |
__cpp_lib_make_unique
|
std::make_unique | 201304L
|
(C++14) | N3656 |
__cpp_lib_map_try_emplace
|
std::map::try_emplace, std::map::insert_or_assign | 201411L
|
(C++17) | N4279 |
__cpp_lib_math_constants
|
數學常數 | 201907L
|
(C++20) | P0631R8 |
__cpp_lib_math_special_functions
|
數學特殊函式 | 201603L
|
(C++17) | P0226R1 |
__cpp_lib_mdspan
|
std::mdspan | 202207L
|
(C++23) | P0009R18 P2599R2 P2604R0 P2613R1 |
std::mdspan 的 std::dims | 202406L
|
(C++26) | P2389R2 | |
__cpp_lib_memory_resource
|
std::pmr::memory_resource | 201603L
|
(C++17) | P0220R1 |
__cpp_lib_modules
|
標準庫模組 std 和 std.compat |
202207L
|
(C++23) | P2465R3 |
__cpp_lib_move_iterator_concept
|
使 std::move_iterator<T*> 成為隨機訪問迭代器 | 202207L
|
(C++23) | P2520R0 |
__cpp_lib_move_only_function
|
std::move_only_function | 202110L
|
(C++23) | P0288R9 |
__cpp_lib_node_extract
|
拼接對映和集合(std::map::extract、std::map::merge、insert(node_type) 等) | 201606L
|
(C++17) | P0083R3 |
__cpp_lib_nonmember_container_access
|
std::size、std::data 和 std::empty | 201411L
|
(C++17) | N4280 |
__cpp_lib_not_fn
|
std::not_fn | 201603L
|
(C++17) | P0005R4 |
允許將可呼叫物件作為非型別模板引數傳遞給 std::not_fn | 202306L
|
(C++26) | P2714R1 | |
__cpp_lib_null_iterators
|
空LegacyForwardIterators | 201304L
|
(C++14) | N3644 |
__cpp_lib_optional
|
std::optional | 201606L
|
(C++17) | P0220R1 P0032R3 P0307R2 |
完全 constexpr std::optional | 202106L
|
(C++23) (DR20) |
P2231R1 | |
std::optional 中的單子操作 | 202110L
|
(C++23) | P0798R8 LWG3621 | |
__cpp_lib_optional_range_support
|
std::optional 範圍支援 | 202406L
|
(C++26) | P3168R2 |
__cpp_lib_out_ptr
|
std::out_ptr, std::inout_ptr | 202106L
|
(C++23) | P1132R8 |
獨立 std::out_ptr, std::inout_ptr | 202311L
|
(C++26) | P2833R2 | |
__cpp_lib_parallel_algorithm
|
並行演算法 | 201603L
|
(C++17) | P0024R2 |
__cpp_lib_polymorphic
|
std::polymorphic | 202502L
|
(C++26) | P3019R13 |
__cpp_lib_polymorphic_allocator
|
將 std::pmr::polymorphic_allocator<> 作為詞彙型別 | 201902L
|
(C++20) | P0339R6 LWG3437 |
__cpp_lib_print
|
格式化輸出 | 202207L
|
(C++23) | P2093R14 |
允許 std::print 的高效實現 | 202403L
|
(C++26) (DR23) |
P3107R5 P3235R3 | |
使用 std::println 列印空行 | 202403L
|
(C++26) | P3142R0 | |
__cpp_lib_quoted_string_io
|
std::quoted | 201304L
|
(C++14) | N3654 |
__cpp_lib_philox_engine
|
std::philox_engine:基於計數器的隨機數引擎 | 202406L
|
(C++26) | P2075R6 |
__cpp_lib_ranges
|
Ranges 庫和受限演算法 | 201911L
|
(C++20) | P0896R4 P1035R7 P1716R3 |
不可預設初始化的檢視 | 202106L
|
(C++23) (DR20) |
P2325R3 | |
具有所有權的檢視 | 202110L
|
P2415R2 | ||
std::ranges::range_adaptor_closure | 202202L
|
(C++23) | P2387R3 | |
放寬範圍介面卡以允許僅可移動型別 | 202207L
|
P2494R2 | ||
移除 ranges::begin、ranges::end、ranges::rbegin、ranges::rend 和 ranges::size 中的“毒丸”過載 | 202211L
|
P2602R2 | ||
放寬範圍以允許某些投影 | 202302L
|
P2609R3 | ||
從間接可呼叫概念中移除通用引用要求 | 202406L
|
(C++26) (DR20) |
P2997R1 | |
__cpp_lib_ranges_as_const
|
std::const_iterator, std::ranges::as_const_view | 202207L
|
(C++23) | P2278R4 |
使 std::basic_const_iterator 遵循其底層型別的可轉換性 | 202311L
|
(C++26) | P2836R1 | |
__cpp_lib_ranges_as_rvalue
|
std::ranges::as_rvalue_view | 202207L
|
(C++23) | P2446R2 |
__cpp_lib_ranges_cache_latest
|
std::ranges::cache_latest_view | 202411L
|
(C++26) | P3138R5 |
__cpp_lib_ranges_cartesian_product
|
std::ranges::cartesian_product_view | 202207L
|
(C++23) | P2374R4 P2540R1 |
__cpp_lib_ranges_chunk
|
std::ranges::chunk_view | 202202L
|
(C++23) | P2442R1 |
__cpp_lib_ranges_chunk_by
|
std::ranges::chunk_by_view | 202202L
|
(C++23) | P2443R1 |
__cpp_lib_ranges_concat
|
std::ranges::concat_view | 202403L
|
(C++26) | P2542R8 |
__cpp_lib_ranges_contains
|
std::ranges::contains | 202207L
|
(C++23) | P2302R4 |
__cpp_lib_ranges_enumerate
|
std::ranges::enumerate_view | 202302L
|
(C++23) | P2164R9 |
__cpp_lib_ranges_find_last
|
std::ranges::find_last、std::ranges::find_last_if 和 std::ranges::find_last_if_not | 202207L
|
(C++23) | P1223R5 LWG3807 |
__cpp_lib_ranges_fold
|
std::ranges 摺疊演算法 |
202207L
|
(C++23) | P2322R6 |
__cpp_lib_ranges_generate_random
|
隨機數生成的向量 API(std::ranges::generate_random) | 202403L
|
(C++26) | P1068R11 |
__cpp_lib_ranges_iota
|
std::ranges::iota | 202202L
|
(C++23) | P2440R1 |
__cpp_lib_ranges_join_with
|
std::ranges::join_with_view | 202202L
|
(C++23) | P2441R2 |
__cpp_lib_ranges_repeat
|
std::ranges::repeat_view | 202207L
|
(C++23) | P2474R2 |
__cpp_lib_ranges_reserve_hint
|
std::ranges::approximately_sized_range 和 std::ranges::reserve_hint | 202502L
|
(C++26) | P2846R6 |
__cpp_lib_ranges_slide
|
std::ranges::slide_view | 202202L
|
(C++23) | P2442R1 |
__cpp_lib_ranges_starts_ends_with
|
std::ranges::starts_with, std::ranges::ends_with | 202106L
|
(C++23) | P1659R3 |
__cpp_lib_ranges_stride
|
std::ranges::stride_view | 202207L
|
(C++23) | P1899R3 |
__cpp_lib_ranges_to_container
|
std::ranges::to | 202202L
|
(C++23) | P1206R7 |
__cpp_lib_ranges_to_input
|
std::ranges::to_input_view | 202502L
|
(C++26) | P3137R3 |
__cpp_lib_ranges_zip
|
std::ranges::zip_view、std::ranges::zip_transform_view、std::ranges::adjacent_view、std::ranges::adjacent_transform_view | 202110L
|
(C++23) | P2321R2 |
__cpp_lib_ratio
|
新增新的 2022 SI 字首 | 202306L
|
(C++26) | P2734R0 |
__cpp_lib_raw_memory_algorithms
|
擴充套件記憶體管理工具 | 201606L
|
(C++17) | P0040R3 |
特殊化記憶體演算法的 constexpr | 202411L
|
(C++26) | P3508R0 P3369R0 | |
__cpp_lib_rcu
|
<rcu>:讀-複製-更新 (RCU) | 202306L
|
(C++26) | P2545R4 |
__cpp_lib_reference_from_temporary
|
std::reference_constructs_from_temporary 和 std::reference_converts_from_temporary | 202202L
|
(C++23) | P2255R2 |
__cpp_lib_reference_wrapper
|
std::reference_wrapper 的比較 | 202403L
|
(C++26) | P2944R3 |
__cpp_lib_remove_cvref
|
std::remove_cvref | 201711L
|
(C++20) | P0550R2 |
__cpp_lib_result_of_sfinae
|
std::result_of 和 SFINAE | 201210L
|
(C++14) | N3462 |
__cpp_lib_robust_nonmodifying_seq_ops
|
使非修改序列操作更健壯(std::mismatch、std::equal 和 std::is_permutation 的雙範圍過載) | 201304L
|
(C++14) | N3671 |
__cpp_lib_sample
|
std::sample | 201603L
|
(C++17) | P0220R1 |
__cpp_lib_saturation_arithmetic
|
飽和算術 | 202311L
|
(C++26) | P0543R3 |
__cpp_lib_scoped_lock
|
std::scoped_lock | 201703L
|
(C++17) | P0156R2 |
__cpp_lib_semaphore
|
std::counting_semaphore, std::binary_semaphore |
201907L
|
(C++20) | P1135R6 |
__cpp_lib_senders
|
std::execution:傳送者-接收者執行控制模型 | 202406L
|
(C++26) | P2300R10 |
__cpp_lib_shared_mutex
|
std::shared_mutex (無時間限制) | 201505L
|
(C++17) | N4508 |
__cpp_lib_shared_ptr_arrays
|
std::shared_ptr<T[]> | 201611L
|
(C++17) | P0497R0 |
std::make_shared 的陣列支援 | 201707L
|
(C++20) | P0674R1 | |
__cpp_lib_shared_ptr_weak_type
|
shared_ptr::weak_type | 201606L
|
(C++17) | P0163R0 |
__cpp_lib_shared_timed_mutex
|
std::shared_timed_mutex | 201402L
|
(C++14) | N3891 |
__cpp_lib_shift
|
std::shift_left 和 std::shift_right | 201806L
|
(C++20) | P0769R2 |
std::ranges::shift_left 和 std::ranges::shift_right | 202202L
|
(C++23) | P2440R1 | |
__cpp_lib_simd
|
<simd>:資料並行型別 | 202411L
|
(C++26) | P1928R15 |
__cpp_lib_smart_ptr_for_overwrite
|
透過預設初始化建立智慧指標(std::allocate_shared_for_overwrite、std::make_shared_for_overwrite、std::make_unique_for_overwrite) | 202002L
|
(C++20) | P1020R1 P1973R1 |
__cpp_lib_smart_ptr_owner_equality
|
在無序關聯容器中啟用std::weak_ptr作為鍵 | 202306L
|
(C++26) | P1901R2 |
__cpp_lib_source_location
|
原始碼資訊捕獲(std::source_location) | 201907L
|
(C++20) | P1208R6 |
__cpp_lib_span
|
std::span | 202002L
|
(C++20) | P0122R7 LWG3274 P1024R3 P1976R2 |
使std::span的部分內容獨立 | 202311L
|
(C++26) | P2821R5 P2833R2 | |
__cpp_lib_span_initializer_list
|
從初始化列表構造std::span | 202311L
|
(C++26) | P2447R6 |
__cpp_lib_spanstream
|
std::spanbuf, std::spanstream | 202106L
|
(C++23) | P0448R4 |
__cpp_lib_ssize
|
std::ssize 和無符號 std::span::size | 201902L
|
(C++20) | P1227R2 |
__cpp_lib_sstream_from_string_view
|
使std::stringstream與std::string_view介面 | 202306L
|
(C++26) | P2495R3 |
__cpp_lib_stacktrace
|
棧跟蹤庫 | 202011L
|
(C++23) | P0881R7 |
__cpp_lib_start_lifetime_as
|
顯式生命週期管理(std::start_lifetime_as) | 202207L
|
(C++23) | P2590R2 |
__cpp_lib_starts_ends_with
|
字串字首和字尾檢查(std::string和std::string_view的starts_with() 和ends_with() ) |
201711L
|
(C++20) | P0457R2 |
__cpp_lib_stdatomic_h
|
C原子操作的相容性標頭檔案 | 202011L
|
(C++23) | P0943R6 |
__cpp_lib_string_contains
|
std::basic_string和std::basic_string_view的contains() |
202011L
|
(C++23) | P1679R3 |
__cpp_lib_string_resize_and_overwrite
|
std::basic_string::resize_and_overwrite | 202110L
|
(C++23) | P1072R10 |
__cpp_lib_string_udls
|
字串型別的使用者定義字面量 | 201304L
|
(C++14) | N3642 |
__cpp_lib_string_view
|
std::string_view | 201606L
|
(C++17) | P0220R1 P0254R2 |
ConstexprIterator(常量表達式迭代器) | 201803L
|
(C++20) | P0858R0 LWG3257 | |
std::string和std::string_view的連線 | 202403L
|
(C++26) | P2591R5 | |
__cpp_lib_submdspan
|
std::submdspan | 202306L
|
(C++26) | P2630R4 |
填充mdspan佈局 | 202403L
|
P2642R6 | ||
__cpp_lib_syncbuf
|
同步緩衝輸出流(std::syncbuf,std::osyncstream)和操縱符 | 201803L
|
(C++20) | P0053R7 P0753R2 |
__cpp_lib_text_encoding
|
std::text_encoding | 202306L
|
(C++26) | P1885R12 |
__cpp_lib_three_way_comparison
|
三路比較(庫支援);向庫新增三路比較 | 201907L
|
(C++20) | P0768R1 P1614R2 |
__cpp_lib_to_address
|
將指標轉換為原始指標的工具(std::to_address) | 201711L
|
(C++20) | P0653R2 |
__cpp_lib_to_array
|
std::to_array | 201907L
|
(C++20) | P0325R4 |
__cpp_lib_to_chars
|
基本字串轉換(std::to_chars, std::from_chars) | 201611L
|
(C++17) | P0067R5 P0682R1 LWG3137 |
測試<charconv>函式的成功或失敗 | 202306L
|
(C++26) | P2497R0 | |
__cpp_lib_to_string
|
根據std::format重新定義std::to_string | 202306L
|
(C++26) | P2587R3 |
__cpp_lib_to_underlying
|
std::to_underlying | 202102L
|
(C++23) | P1682R3 |
__cpp_lib_transformation_trait_aliases
|
型別轉換特性的別名模板 | 201304L
|
(C++14) | N3655 |
__cpp_lib_transparent_operators
|
透明運算子函式物件(std::less<>等) | 201210L
|
(C++14) | N3421 |
透明std::owner_less(std::owner_less<void>) | 201510L
|
(C++17) | P0074R0 | |
__cpp_lib_trivially_relocatable
|
平凡可重定位特性和操作 | 202502L
|
(C++26) | P2786R13 |
__cpp_lib_tuple_element_t
|
std::tuple_element_t | 201402L
|
(C++14) | N3887 |
__cpp_lib_tuple_like
|
std::tuple與類元組物件(std::pair、std::array、std::subrange)之間的相容性 | 202207L
|
(C++23) | P2165R4 |
將元組協議新增到std::complex | 202311L
|
(C++26) | P2819R2 | |
__cpp_lib_tuples_by_type
|
按型別定址元組 | 201304L
|
(C++14) | N3670 |
__cpp_lib_type_identity
|
std::type_identity | 201806L
|
(C++20) | P0887R1 |
__cpp_lib_type_trait_variable_templates
|
型別特性變數模板(std::is_void_v等) | 201510L
|
(C++17) | P0006R0 |
__cpp_lib_uncaught_exceptions
|
std::uncaught_exceptions | 201411L
|
(C++17) | N4259 |
__cpp_lib_unordered_map_try_emplace
|
std::unordered_map::try_emplace, std::unordered_map::insert_or_assign | 201411L
|
(C++17) | N4279 |
__cpp_lib_unreachable
|
std::unreachable | 202202L
|
(C++23) | P0627R6 |
__cpp_lib_unwrap_ref
|
std::unwrap_ref_decay 和 std::unwrap_reference | 201811L
|
(C++20) | P0318R1 LWG3348 |
__cpp_lib_variant
|
std::variant: C++17 的型別安全聯合 | 201606L
|
(C++17) | P0088R3 P0393R3 P0032R3 |
針對派生自std::variant的類的std::visit | 202102L
|
(C++23) (DR17) |
P2162R2 | |
完全constexpr std::variant | 202106L
|
(C++23) (DR20) |
P2231R1 | |
成員visit | 202306L
|
(C++26) | P2637R3 | |
__cpp_lib_void_t
|
std::void_t | 201411L
|
(C++17) | N3911 |
宏總數:255 |
[編輯] 示例
[編輯] 正常用法
#ifdef __has_include // Check if __has_include is present # if __has_include(<optional>) // Check for a standard library # include <optional> # elif __has_include(<experimental/optional>) // Check for an experimental version # include <experimental/optional> # elif __has_include(<boost/optional.hpp>) // Try with an external library # include <boost/optional.hpp> # else // Not found at all # error "Missing <optional>" # endif #endif #ifdef __has_cpp_attribute // Check if __has_cpp_attribute is present # if __has_cpp_attribute(deprecated) // Check for an attribute # define DEPRECATED(msg) [[deprecated(msg)]] # endif #endif #ifndef DEPRECATED # define DEPRECATED(msg) #endif DEPRECATED("foo() has been deprecated") void foo(); #if __cpp_constexpr >= 201304 // Check for a specific version of a feature # define CONSTEXPR constexpr #else # define CONSTEXPR inline #endif CONSTEXPR int bar(unsigned i) { #if __cpp_binary_literals // Check for the presence of a feature unsigned mask1 = 0b11000000; unsigned mask2 = 0b00000111; #else unsigned mask1 = 0xC0; unsigned mask2 = 0x07; #endif if (i & mask1) return 1; if (i & mask2) return 2; return 0; } int main() {}
[編輯] 編譯器特性轉儲
以下(C++11 相容)程式轉儲 C++ 編譯器特性和屬性。請注意,使用__has_cpp_attribute()不符合標準,並依賴於 gcc/clang 實現。
static constexpr struct change_these_options_to_select_what_will_be_printed { constexpr static int longest_macro_name { 45 }; constexpr static bool titles = 1; constexpr static bool counters = 1; constexpr static bool attributes = 1; constexpr static bool standard_values = 1; constexpr static bool compiler_specific = 1; constexpr static bool core_features = 1; constexpr static bool lib_features = 1; constexpr static bool supported_features = 1; constexpr static bool unsupported_features = 1; constexpr static bool sort_by_date = 0; constexpr static bool separate_year_month = 1; constexpr static bool separated_revisions = 1; constexpr static bool latest_revisions = 1; constexpr static bool cxx98 = 0; constexpr static bool cxx11 = 1; constexpr static bool cxx14 = 1; constexpr static bool cxx17 = 1; constexpr static bool cxx20 = 1; constexpr static bool cxx23 = 1; constexpr static bool cxx26 = 1; constexpr static bool cxx29 = 0; } print; #if __cplusplus < 201100 # error "C++11 or better is required" #endif #include <algorithm> #include <cstdio> #include <cstring> #include <utility> #include <vector> #ifdef __has_include # if __has_include(<version>) # include <version> # endif #endif // Expect a string that starts with 6-decimal-digits or with '_' (if unsupported) #define COMPILER_VALUE_INT(n) #n [0] == '_' ? 0 : \ (#n[5] - '0') + (#n[4] - '0') * 10 + (#n[3] - '0') * 100 + \ (#n[2] - '0') * 1000 + (#n[1] - '0') * 10000 + (#n[0] - '0') * 100000 #define COMPILER_FEATURE_ENTRY(expect, name) { #name, COMPILER_VALUE_INT(name), expect }, #if defined(__has_cpp_attribute) && defined(__GNUG__) # define COMPILER_ATTRIBUTE(expect, name) { #name, __has_cpp_attribute(name), expect }, #else # define COMPILER_ATTRIBUTE(expect, name) { #name, COMPILER_VALUE_INT(name), expect }, #endif #define COMPILER_SPECIFIC_STRING(value) #value #define COMPILER_SPECIFIC_ENTRY(name) { #name, COMPILER_SPECIFIC_STRING(name) }, class CompilerFeature { char const* name_; long data_; long std_; public: constexpr CompilerFeature(char const* name, long data, long std) : name_(name), data_(data), std_(std) {} constexpr CompilerFeature(CompilerFeature const&) = default; CompilerFeature& operator=(CompilerFeature const&) = default; bool operator<(CompilerFeature const& rhs) const { return std::strcmp(name_, rhs.name_) < 0; } bool operator==(CompilerFeature const& rhs) const { return std::strcmp(name_, rhs.name_) == 0; } constexpr bool supported() const { return data_ >= std_; } constexpr bool maybe() const { return data_ > 0; } constexpr char const* name() const { return name_; } constexpr long std() const { return std_; } constexpr long data() const { return data_; } void data(long x) { data_ = x; } }; static /*constexpr*/ std::pair<const char*, const char*> compiler[] = { COMPILER_SPECIFIC_ENTRY(__cplusplus) //< not compiler specific, but useful :) COMPILER_SPECIFIC_ENTRY(__clang_major__) COMPILER_SPECIFIC_ENTRY(__clang_minor__) COMPILER_SPECIFIC_ENTRY(__clang_patchlevel__) COMPILER_SPECIFIC_ENTRY(__GNUG__) COMPILER_SPECIFIC_ENTRY(__GNUC_MINOR__) COMPILER_SPECIFIC_ENTRY(__GNUC_PATCHLEVEL__) // Add your favorite compiler specific macros. Undefined ones will not be printed. }; static constexpr CompilerFeature cxx98_core[] = { COMPILER_FEATURE_ENTRY(199711L, __cpp_exceptions) COMPILER_FEATURE_ENTRY(199711L, __cpp_rtti) }; static constexpr CompilerFeature cxx11_core[] = { COMPILER_FEATURE_ENTRY(200704L, __cpp_alias_templates) COMPILER_FEATURE_ENTRY(200809L, __cpp_attributes) COMPILER_FEATURE_ENTRY(200704L, __cpp_constexpr) COMPILER_FEATURE_ENTRY(201711L, __cpp_constexpr_in_decltype) COMPILER_FEATURE_ENTRY(200707L, __cpp_decltype) COMPILER_FEATURE_ENTRY(200604L, __cpp_delegating_constructors) COMPILER_FEATURE_ENTRY(201511L, __cpp_inheriting_constructors) COMPILER_FEATURE_ENTRY(200806L, __cpp_initializer_lists) COMPILER_FEATURE_ENTRY(200907L, __cpp_lambdas) COMPILER_FEATURE_ENTRY(200809L, __cpp_nsdmi) COMPILER_FEATURE_ENTRY(200907L, __cpp_range_based_for) COMPILER_FEATURE_ENTRY(200710L, __cpp_raw_strings) COMPILER_FEATURE_ENTRY(200710L, __cpp_ref_qualifiers) COMPILER_FEATURE_ENTRY(200610L, __cpp_rvalue_references) COMPILER_FEATURE_ENTRY(200410L, __cpp_static_assert) COMPILER_FEATURE_ENTRY(200806L, __cpp_threadsafe_static_init) COMPILER_FEATURE_ENTRY(200704L, __cpp_unicode_characters) COMPILER_FEATURE_ENTRY(200710L, __cpp_unicode_literals) COMPILER_FEATURE_ENTRY(200809L, __cpp_user_defined_literals) COMPILER_FEATURE_ENTRY(200704L, __cpp_variadic_templates) }; static constexpr CompilerFeature cxx14_core[] = { COMPILER_FEATURE_ENTRY(201304L, __cpp_aggregate_nsdmi) COMPILER_FEATURE_ENTRY(201304L, __cpp_binary_literals) COMPILER_FEATURE_ENTRY(201304L, __cpp_constexpr) COMPILER_FEATURE_ENTRY(201304L, __cpp_decltype_auto) COMPILER_FEATURE_ENTRY(201304L, __cpp_generic_lambdas) COMPILER_FEATURE_ENTRY(201304L, __cpp_init_captures) COMPILER_FEATURE_ENTRY(201304L, __cpp_return_type_deduction) COMPILER_FEATURE_ENTRY(201309L, __cpp_sized_deallocation) COMPILER_FEATURE_ENTRY(201304L, __cpp_variable_templates) }; static constexpr CompilerFeature cxx14_lib[] = { COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_chrono_udls) COMPILER_FEATURE_ENTRY(201309L, __cpp_lib_complex_udls) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_exchange_function) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_generic_associative_lookup) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_integer_sequence) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_integral_constant_callable) COMPILER_FEATURE_ENTRY(201402L, __cpp_lib_is_final) COMPILER_FEATURE_ENTRY(201309L, __cpp_lib_is_null_pointer) COMPILER_FEATURE_ENTRY(201402L, __cpp_lib_make_reverse_iterator) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_make_unique) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_null_iterators) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_quoted_string_io) COMPILER_FEATURE_ENTRY(201210L, __cpp_lib_result_of_sfinae) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_robust_nonmodifying_seq_ops) COMPILER_FEATURE_ENTRY(201402L, __cpp_lib_shared_timed_mutex) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_string_udls) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_transformation_trait_aliases) COMPILER_FEATURE_ENTRY(201210L, __cpp_lib_transparent_operators) COMPILER_FEATURE_ENTRY(201402L, __cpp_lib_tuple_element_t) COMPILER_FEATURE_ENTRY(201304L, __cpp_lib_tuples_by_type) }; static constexpr CompilerFeature cxx17_core[] = { COMPILER_FEATURE_ENTRY(201603L, __cpp_aggregate_bases) COMPILER_FEATURE_ENTRY(201606L, __cpp_aligned_new) COMPILER_FEATURE_ENTRY(201603L, __cpp_capture_star_this) COMPILER_FEATURE_ENTRY(201603L, __cpp_constexpr) COMPILER_FEATURE_ENTRY(201703L, __cpp_deduction_guides) COMPILER_FEATURE_ENTRY(201411L, __cpp_enumerator_attributes) COMPILER_FEATURE_ENTRY(201603L, __cpp_fold_expressions) COMPILER_FEATURE_ENTRY(201606L, __cpp_guaranteed_copy_elision) COMPILER_FEATURE_ENTRY(201603L, __cpp_hex_float) COMPILER_FEATURE_ENTRY(201606L, __cpp_if_constexpr) COMPILER_FEATURE_ENTRY(201606L, __cpp_inline_variables) COMPILER_FEATURE_ENTRY(201411L, __cpp_namespace_attributes) COMPILER_FEATURE_ENTRY(201510L, __cpp_noexcept_function_type) COMPILER_FEATURE_ENTRY(201411L, __cpp_nontype_template_args) COMPILER_FEATURE_ENTRY(201606L, __cpp_nontype_template_parameter_auto) COMPILER_FEATURE_ENTRY(201603L, __cpp_range_based_for) COMPILER_FEATURE_ENTRY(201411L, __cpp_static_assert) COMPILER_FEATURE_ENTRY(201606L, __cpp_structured_bindings) COMPILER_FEATURE_ENTRY(201611L, __cpp_template_template_args) COMPILER_FEATURE_ENTRY(201611L, __cpp_variadic_using) }; static constexpr CompilerFeature cxx17_lib[] = { COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_addressof_constexpr) COMPILER_FEATURE_ENTRY(201411L, __cpp_lib_allocator_traits_is_always_equal) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_any) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_apply) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_array_constexpr) COMPILER_FEATURE_ENTRY(201510L, __cpp_lib_as_const) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_atomic_is_always_lock_free) COMPILER_FEATURE_ENTRY(201505L, __cpp_lib_bool_constant) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_boyer_moore_searcher) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_byte) COMPILER_FEATURE_ENTRY(201611L, __cpp_lib_chrono) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_clamp) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_enable_shared_from_this) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_execution) COMPILER_FEATURE_ENTRY(201703L, __cpp_lib_filesystem) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_gcd_lcm) COMPILER_FEATURE_ENTRY(201703L, __cpp_lib_hardware_interference_size) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_has_unique_object_representations) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_hypot) COMPILER_FEATURE_ENTRY(201505L, __cpp_lib_incomplete_container_elements) COMPILER_FEATURE_ENTRY(201411L, __cpp_lib_invoke) COMPILER_FEATURE_ENTRY(201703L, __cpp_lib_is_aggregate) COMPILER_FEATURE_ENTRY(201703L, __cpp_lib_is_invocable) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_is_swappable) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_launder) COMPILER_FEATURE_ENTRY(201510L, __cpp_lib_logical_traits) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_make_from_tuple) COMPILER_FEATURE_ENTRY(201411L, __cpp_lib_map_try_emplace) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_math_special_functions) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_memory_resource) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_node_extract) COMPILER_FEATURE_ENTRY(201411L, __cpp_lib_nonmember_container_access) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_not_fn) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_optional) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_parallel_algorithm) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_raw_memory_algorithms) COMPILER_FEATURE_ENTRY(201603L, __cpp_lib_sample) COMPILER_FEATURE_ENTRY(201703L, __cpp_lib_scoped_lock) COMPILER_FEATURE_ENTRY(201505L, __cpp_lib_shared_mutex) COMPILER_FEATURE_ENTRY(201611L, __cpp_lib_shared_ptr_arrays) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_shared_ptr_weak_type) COMPILER_FEATURE_ENTRY(201606L, __cpp_lib_string_view) COMPILER_FEATURE_ENTRY(201611L, __cpp_lib_to_chars) COMPILER_FEATURE_ENTRY(201510L, __cpp_lib_transparent_operators) COMPILER_FEATURE_ENTRY(201510L, __cpp_lib_type_trait_variable_templates) COMPILER_FEATURE_ENTRY(201411L, __cpp_lib_uncaught_exceptions) COMPILER_FEATURE_ENTRY(201411L, __cpp_lib_unordered_map_try_emplace) COMPILER_FEATURE_ENTRY(202102L, __cpp_lib_variant) COMPILER_FEATURE_ENTRY(201411L, __cpp_lib_void_t) }; static constexpr CompilerFeature cxx20_core[] = { COMPILER_FEATURE_ENTRY(201902L, __cpp_aggregate_paren_init) COMPILER_FEATURE_ENTRY(202207L, __cpp_char8_t) COMPILER_FEATURE_ENTRY(202002L, __cpp_concepts) COMPILER_FEATURE_ENTRY(201806L, __cpp_conditional_explicit) COMPILER_FEATURE_ENTRY(202211L, __cpp_consteval) COMPILER_FEATURE_ENTRY(202002L, __cpp_constexpr) COMPILER_FEATURE_ENTRY(201907L, __cpp_constexpr_dynamic_alloc) COMPILER_FEATURE_ENTRY(201907L, __cpp_constinit) COMPILER_FEATURE_ENTRY(201907L, __cpp_deduction_guides) COMPILER_FEATURE_ENTRY(201707L, __cpp_designated_initializers) COMPILER_FEATURE_ENTRY(201707L, __cpp_generic_lambdas) COMPILER_FEATURE_ENTRY(201902L, __cpp_impl_coroutine) COMPILER_FEATURE_ENTRY(201806L, __cpp_impl_destroying_delete) COMPILER_FEATURE_ENTRY(201907L, __cpp_impl_three_way_comparison) COMPILER_FEATURE_ENTRY(201803L, __cpp_init_captures) COMPILER_FEATURE_ENTRY(201907L, __cpp_modules) COMPILER_FEATURE_ENTRY(201911L, __cpp_nontype_template_args) COMPILER_FEATURE_ENTRY(201907L, __cpp_using_enum) }; static constexpr CompilerFeature cxx20_lib[] = { COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_array_constexpr) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_assume_aligned) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_atomic_flag_test) COMPILER_FEATURE_ENTRY(201711L, __cpp_lib_atomic_float) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_atomic_lock_free_type_aliases) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_atomic_ref) COMPILER_FEATURE_ENTRY(201711L, __cpp_lib_atomic_shared_ptr) COMPILER_FEATURE_ENTRY(201911L, __cpp_lib_atomic_value_initialization) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_atomic_wait) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_barrier) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_bind_front) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_bit_cast) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_bitops) COMPILER_FEATURE_ENTRY(201902L, __cpp_lib_bounded_array_traits) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_char8_t) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_chrono) COMPILER_FEATURE_ENTRY(202002L, __cpp_lib_concepts) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_constexpr_algorithms) COMPILER_FEATURE_ENTRY(201711L, __cpp_lib_constexpr_complex) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_constexpr_dynamic_alloc) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_constexpr_functional) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_constexpr_iterator) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_constexpr_memory) COMPILER_FEATURE_ENTRY(201911L, __cpp_lib_constexpr_numeric) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_constexpr_string) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_constexpr_string_view) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_constexpr_tuple) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_constexpr_utility) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_constexpr_vector) COMPILER_FEATURE_ENTRY(201902L, __cpp_lib_coroutine) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_destroying_delete) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_endian) COMPILER_FEATURE_ENTRY(202002L, __cpp_lib_erase_if) COMPILER_FEATURE_ENTRY(201902L, __cpp_lib_execution) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_format) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_generic_unordered_lookup) COMPILER_FEATURE_ENTRY(202002L, __cpp_lib_int_pow2) COMPILER_FEATURE_ENTRY(202002L, __cpp_lib_integer_comparison_functions) COMPILER_FEATURE_ENTRY(201902L, __cpp_lib_interpolate) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_is_constant_evaluated) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_is_layout_compatible) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_is_nothrow_convertible) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_is_pointer_interconvertible) COMPILER_FEATURE_ENTRY(201911L, __cpp_lib_jthread) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_latch) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_list_remove_return_type) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_math_constants) COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_optional) COMPILER_FEATURE_ENTRY(201902L, __cpp_lib_polymorphic_allocator) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_ranges) COMPILER_FEATURE_ENTRY(201711L, __cpp_lib_remove_cvref) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_semaphore) COMPILER_FEATURE_ENTRY(201707L, __cpp_lib_shared_ptr_arrays) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_shift) COMPILER_FEATURE_ENTRY(202002L, __cpp_lib_smart_ptr_for_overwrite) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_source_location) COMPILER_FEATURE_ENTRY(202002L, __cpp_lib_span) COMPILER_FEATURE_ENTRY(201902L, __cpp_lib_ssize) COMPILER_FEATURE_ENTRY(201711L, __cpp_lib_starts_ends_with) COMPILER_FEATURE_ENTRY(201803L, __cpp_lib_string_view) COMPILER_FEATURE_ENTRY(201803L, __cpp_lib_syncbuf) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_three_way_comparison) COMPILER_FEATURE_ENTRY(201711L, __cpp_lib_to_address) COMPILER_FEATURE_ENTRY(201907L, __cpp_lib_to_array) COMPILER_FEATURE_ENTRY(201806L, __cpp_lib_type_identity) COMPILER_FEATURE_ENTRY(201811L, __cpp_lib_unwrap_ref) COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_variant) }; static constexpr CompilerFeature cxx23_core[] = { COMPILER_FEATURE_ENTRY(202110L, __cpp_auto_cast) COMPILER_FEATURE_ENTRY(202211L, __cpp_constexpr) COMPILER_FEATURE_ENTRY(202110L, __cpp_explicit_this_parameter) COMPILER_FEATURE_ENTRY(202106L, __cpp_if_consteval) COMPILER_FEATURE_ENTRY(202207L, __cpp_implicit_move) COMPILER_FEATURE_ENTRY(202211L, __cpp_multidimensional_subscript) COMPILER_FEATURE_ENTRY(202207L, __cpp_named_character_escapes) COMPILER_FEATURE_ENTRY(202211L, __cpp_range_based_for) COMPILER_FEATURE_ENTRY(202011L, __cpp_size_t_suffix) COMPILER_FEATURE_ENTRY(202207L, __cpp_static_call_operator) }; static constexpr CompilerFeature cxx23_lib[] = { COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_adaptor_iterator_pair_constructor) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_algorithm_iterator_requirements) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_allocate_at_least) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_associative_heterogeneous_erasure) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_barrier) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_bind_back) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_byteswap) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_common_reference) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_common_reference_wrapper) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_concepts) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_constexpr_bitset) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_constexpr_charconv) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_constexpr_cmath) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_constexpr_memory) COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_constexpr_typeinfo) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_containers_ranges) COMPILER_FEATURE_ENTRY(202211L, __cpp_lib_expected) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_flat_map) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_flat_set) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_format) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_format_ranges) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_formatters) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_forward_like) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_generator) COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_invoke_r) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ios_noreplace) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_is_implicit_lifetime) COMPILER_FEATURE_ENTRY(202011L, __cpp_lib_is_scoped_enum) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_mdspan) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_modules) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_move_iterator_concept) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_move_only_function) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_optional) COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_out_ptr) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_print) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_ranges) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_as_const) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_as_rvalue) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_cartesian_product) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_ranges_chunk) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_ranges_chunk_by) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_contains) COMPILER_FEATURE_ENTRY(202302L, __cpp_lib_ranges_enumerate) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_find_last) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_fold) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_ranges_iota) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_ranges_join_with) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_repeat) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_ranges_slide) COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_ranges_starts_ends_with) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_ranges_stride) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_ranges_to_container) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_ranges_zip) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_reference_from_temporary) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_shift) COMPILER_FEATURE_ENTRY(202106L, __cpp_lib_spanstream) COMPILER_FEATURE_ENTRY(202011L, __cpp_lib_stacktrace) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_start_lifetime_as) COMPILER_FEATURE_ENTRY(202011L, __cpp_lib_stdatomic_h) COMPILER_FEATURE_ENTRY(202011L, __cpp_lib_string_contains) COMPILER_FEATURE_ENTRY(202110L, __cpp_lib_string_resize_and_overwrite) COMPILER_FEATURE_ENTRY(202102L, __cpp_lib_to_underlying) COMPILER_FEATURE_ENTRY(202207L, __cpp_lib_tuple_like) COMPILER_FEATURE_ENTRY(202202L, __cpp_lib_unreachable) }; static constexpr CompilerFeature cxx26_core[] = { //< Continue to Populate COMPILER_FEATURE_ENTRY(202406L, __cpp_constexpr) COMPILER_FEATURE_ENTRY(202411L, __cpp_constexpr_exceptions) COMPILER_FEATURE_ENTRY(202502L, __cpp_contracts) COMPILER_FEATURE_ENTRY(202403L, __cpp_deleted_function) COMPILER_FEATURE_ENTRY(202406L, __cpp_fold_expressions) COMPILER_FEATURE_ENTRY(202311L, __cpp_pack_indexing) COMPILER_FEATURE_ENTRY(202306L, __cpp_placeholder_variables) COMPILER_FEATURE_ENTRY(202502L, __cpp_pp_embed) COMPILER_FEATURE_ENTRY(202306L, __cpp_static_assert) COMPILER_FEATURE_ENTRY(202411L, __cpp_structured_bindings) COMPILER_FEATURE_ENTRY(202502L, __cpp_template_parameters) COMPILER_FEATURE_ENTRY(202502L, __cpp_trivial_relocatability) COMPILER_FEATURE_ENTRY(202502L, __cpp_trivial_union) COMPILER_FEATURE_ENTRY(202403L, __cpp_variadic_friend) }; static constexpr CompilerFeature cxx26_lib[] = { //< Continue to Populate COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_algorithm_default_value_type) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_aligned_accessor) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_associative_heterogeneous_insertion) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_atomic_min_max) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_atomic_ref) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_bind_back) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_bind_front) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_bitset) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_chrono) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_constexpr_algorithms) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_constexpr_atomic) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_constexpr_cmath) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_constexpr_complex) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_constexpr_containers) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_constexpr_exceptions) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_constexpr_exceptions) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_constexpr_inplace_vector) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_constexpr_new) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_constrained_equality) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_contracts) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_copyable_function) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_debugging) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_format) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_format_path) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_format_uchar) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_algorithm) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_array) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_char_traits) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_charconv) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_cstdlib) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_cstring) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_cwchar) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_errc) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_expected) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_feature_test_macros) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_functional) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_iterator) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_mdspan) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_memory) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_numeric) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_operator_new) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_optional) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_ranges) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_ratio) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_string_view) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_tuple) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_freestanding_utility) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_freestanding_variant) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_fstream_native_handle) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_function_ref) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_hazard_pointer) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_hive) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_indirect) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_inplace_vector) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_is_sufficiently_aligned) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_is_virtual_base_of) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_is_within_lifetime) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_linalg) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_mdspan) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_not_fn) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_optional_range_support) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_out_ptr) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_philox_engine) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_polymorphic) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_print) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_ranges) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_ranges_as_const) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_ranges_cache_latest) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_ranges_concat) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_ranges_generate_random) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_ranges_reserve_hint) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_ranges_to_input) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_ratio) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_raw_memory_algorithms) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_rcu) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_reference_wrapper) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_saturation_arithmetic) COMPILER_FEATURE_ENTRY(202406L, __cpp_lib_senders) COMPILER_FEATURE_ENTRY(202411L, __cpp_lib_simd) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_smart_ptr_owner_equality) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_span) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_span_initializer_list) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_sstream_from_string_view) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_string_view) COMPILER_FEATURE_ENTRY(202403L, __cpp_lib_submdspan) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_text_encoding) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_to_chars) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_to_string) COMPILER_FEATURE_ENTRY(202502L, __cpp_lib_trivially_relocatable) COMPILER_FEATURE_ENTRY(202311L, __cpp_lib_tuple_like) COMPILER_FEATURE_ENTRY(202306L, __cpp_lib_variant) }; static constexpr CompilerFeature cxx29_core[] = { //< Continue to Populate COMPILER_FEATURE_ENTRY(202604L, __cpp_core_TODO) }; static constexpr CompilerFeature cxx29_lib[] = { //< Continue to Populate COMPILER_FEATURE_ENTRY(202604L, __cpp_lib_TODO) }; static constexpr CompilerFeature attributes[] = { COMPILER_ATTRIBUTE(202207L, assume) COMPILER_ATTRIBUTE(200809L, carries_dependency) COMPILER_ATTRIBUTE(201309L, deprecated) COMPILER_ATTRIBUTE(201603L, fallthrough) COMPILER_ATTRIBUTE(202403L, indeterminate) COMPILER_ATTRIBUTE(201803L, likely) COMPILER_ATTRIBUTE(201603L, maybe_unused) COMPILER_ATTRIBUTE(201803L, no_unique_address) COMPILER_ATTRIBUTE(201907L, nodiscard) COMPILER_ATTRIBUTE(200809L, noreturn) COMPILER_ATTRIBUTE(201803L, unlikely) }; inline void show_compiler_specific_info() { std::printf("Compiler specific macros:\n"); for (auto co : compiler) if (std::strcmp(co.first, co.second)) std::printf("%*s %s\n", -print.longest_macro_name, co.first, co.second); } inline void print_compiler_feature(const CompilerFeature& x) { if (not ((print.supported_features and x.maybe()) or (print.unsupported_features and not x.maybe()))) return; auto print_year_month = [](long n) { return std::printf("%ld%s%02ld", n / 100, print.separate_year_month ? "-" : "", n % 100); }; std::printf("%*s ", -print.longest_macro_name, x.name()); x.maybe() ? print_year_month(x.data()) : std::printf("------%s", print.separate_year_month ? "-" : ""); if (print.standard_values) std::printf(" %c ", (x.supported() ? (x.data() > x.std() ? '>' : '=') : '<')), print_year_month(x.std()); std::puts(""); } template<class Container> inline void show(char const* const title, Container const& co) { if (print.titles) { std::printf("%-s (", title); if (print.counters) { std::printf("%zd/", std::count_if(std::begin(co), std::end(co), [](CompilerFeature x) { return x.supported(); })); } std::printf("%td)\n", std::distance(std::begin(co), std::end(co))); } if (print.sort_by_date) { std::vector<CompilerFeature> v(std::begin(co), std::end(co)); std::stable_sort(v.begin(), v.end(), [](CompilerFeature const& lhs, CompilerFeature const& rhs) { return lhs.data() < rhs.data(); }); std::for_each(v.cbegin(), v.cend(), print_compiler_feature); } else std::for_each(std::begin(co), std::end(co), print_compiler_feature); std::puts(""); } inline void show_latest() { auto latest_rev = []() -> int { return print.cxx29 ? 29 : print.cxx26 ? 26 : print.cxx23 ? 23 : print.cxx20 ? 20 : print.cxx17 ? 17 : print.cxx14 ? 14 : print.cxx11 ? 11 : 98; }; std::vector<CompilerFeature> latest; auto add = [&latest](CompilerFeature x) { auto i = std::lower_bound(latest.begin(), latest.end(), x); if (i == latest.end() or not (*i == x)) latest.insert(i, x); else if (i->data() < x.data()) i->data(x.data()); }; char text[64]; latest.reserve(512); // max macros if (print.core_features) { // preserve reverse revision insertion order! if (print.cxx29) std::for_each(std::begin(cxx29_core), std::end(cxx29_core), add); if (print.cxx26) std::for_each(std::begin(cxx26_core), std::end(cxx26_core), add); if (print.cxx23) std::for_each(std::begin(cxx23_core), std::end(cxx23_core), add); if (print.cxx20) std::for_each(std::begin(cxx20_core), std::end(cxx20_core), add); if (print.cxx17) std::for_each(std::begin(cxx17_core), std::end(cxx17_core), add); if (print.cxx14) std::for_each(std::begin(cxx14_core), std::end(cxx14_core), add); if (print.cxx11) std::for_each(std::begin(cxx11_core), std::end(cxx11_core), add); if (print.cxx98) std::for_each(std::begin(cxx98_core), std::end(cxx98_core), add); std::snprintf(text, sizeof text, "ALL CORE MACROS UP TO C++%02i", latest_rev()); show(text, latest); } latest.clear(); if (print.lib_features) { // preserve reverse revision insertion order! if (print.cxx29) std::for_each(std::begin(cxx29_lib), std::end(cxx29_lib), add); if (print.cxx26) std::for_each(std::begin(cxx26_lib), std::end(cxx26_lib), add); if (print.cxx23) std::for_each(std::begin(cxx23_lib), std::end(cxx23_lib), add); if (print.cxx20) std::for_each(std::begin(cxx20_lib), std::end(cxx20_lib), add); if (print.cxx17) std::for_each(std::begin(cxx17_lib), std::end(cxx17_lib), add); if (print.cxx14) std::for_each(std::begin(cxx14_lib), std::end(cxx14_lib), add); std::snprintf(text, sizeof text, "ALL LIB MACROS UP TO C++%02i", latest_rev()); show(text, latest); } } int main() { if (print.separated_revisions) { if (print.cxx98 and print.core_features) show("C++98 CORE", cxx98_core); if (print.cxx11 and print.core_features) show("C++11 CORE", cxx11_core); if (print.cxx14 and print.core_features) show("C++14 CORE", cxx14_core); if (print.cxx14 and print.lib_features ) show("C++14 LIB" , cxx14_lib); if (print.cxx17 and print.core_features) show("C++17 CORE", cxx17_core); if (print.cxx17 and print.lib_features ) show("C++17 LIB" , cxx17_lib); if (print.cxx20 and print.core_features) show("C++20 CORE", cxx20_core); if (print.cxx20 and print.lib_features ) show("C++20 LIB" , cxx20_lib); if (print.cxx23 and print.core_features) show("C++23 CORE", cxx23_core); if (print.cxx23 and print.lib_features ) show("C++23 LIB" , cxx23_lib); if (print.cxx26 and print.core_features) show("C++26 CORE", cxx26_core); if (print.cxx26 and print.lib_features ) show("C++26 LIB" , cxx26_lib); if (print.cxx29 and print.core_features) show("C++29 CORE", cxx29_core); if (print.cxx29 and print.lib_features ) show("C++29 LIB" , cxx29_lib); } if (print.latest_revisions) show_latest(); if (print.attributes) show("ATTRIBUTES", attributes); if (print.compiler_specific) show_compiler_specific_info(); }
可能的輸出
C++11 CORE (20/20) __cpp_alias_templates 2007-04 = 2007-04 __cpp_attributes 2008-09 = 2008-09 __cpp_constexpr 2022-11 > 2007-04 __cpp_constexpr_in_decltype 2017-11 = 2017-11 ... truncated ... C++14 CORE (9/9) __cpp_aggregate_nsdmi 2013-04 = 2013-04 __cpp_binary_literals 2013-04 = 2013-04 __cpp_constexpr 2022-11 > 2013-04 ... truncated ... C++14 LIB (20/20) __cpp_lib_chrono_udls 2013-04 = 2013-04 __cpp_lib_complex_udls 2013-09 = 2013-09 __cpp_lib_exchange_function 2013-04 = 2013-04 ... truncated ... ... truncated ... C++23 LIB (43/64) __cpp_lib_adaptor_iterator_pair_constructor 2021-06 = 2021-06 __cpp_lib_algorithm_iterator_requirements ------- < 2022-07 __cpp_lib_allocate_at_least ------- < 2023-02 __cpp_lib_associative_heterogeneous_erasure ------- < 2021-10 __cpp_lib_barrier 2019-07 < 2023-02 ... truncated ... ALL CORE MACROS UP TO C++26 (60/76) __cpp_aggregate_bases 2016-03 = 2016-03 __cpp_aggregate_nsdmi 2013-04 = 2013-04 __cpp_aggregate_paren_init 2019-02 = 2019-02 __cpp_alias_templates 2007-04 = 2007-04 ... truncated ... ALL LIB MACROS UP TO C++26 (158/255) __cpp_lib_adaptor_iterator_pair_constructor 2021-06 = 2021-06 __cpp_lib_addressof_constexpr 2016-03 = 2016-03 __cpp_lib_algorithm_iterator_requirements ------- < 2022-07 __cpp_lib_allocate_at_least ------- < 2023-02 __cpp_lib_allocator_traits_is_always_equal 2014-11 = 2014-11 ... truncated ... ATTRIBUTES (9/11) assume 2022-07 = 2022-07 carries_dependency ------- < 2008-09 deprecated 2013-09 = 2013-09 fallthrough 2016-03 = 2016-03 ... truncated ... Compiler specific macros: __cplusplus 202302L __GNUG__ 14 __GNUC_MINOR__ 2 __GNUC_PATCHLEVEL__ 0
[編輯] 缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
P2552R3 | C++20 | __has_cpp_attribute 對於標準屬性必須擴充套件為非零值 |
可擴充套件為0 |
[編輯] 另請參閱
庫特性測試宏 (C++20) | 在標頭檔案<version>中定義 |
預定義宏符號 | |
宏符號索引 |
[編輯] 外部連結
1. | 特性測試建議的官方文件 |
2. | 轉儲編譯器特性的原始碼 |