您现在的位置是:首页 >其他 >检测并打印C++编译器支持的feature(附Visual Studio 2022和gcc-12测试、对比结果)网站首页其他

检测并打印C++编译器支持的feature(附Visual Studio 2022和gcc-12测试、对比结果)

抓饼先生 2023-06-15 04:00:02
简介检测并打印C++编译器支持的feature(附Visual Studio 2022和gcc-12测试、对比结果)

C++标准快速迭代,不同的系统平台和编译器对C++各种新功能的支持不同,通过这个程序可以测试所用编译器对各个版本C++的支持情况。另一方面,可以在代码中通过这些宏针对不同版本编写不同的代码分支。
源码下面附上Visual Studio 2022的测试结果,基本上在2021年中就把C++23(当时还是草案)大部分功能都支持了。

测试代码

测试代码引用网址:https://en.cppreference.com/w/cpp/feature_test

#if __cplusplus < 201100
#  error "C++11 or better is required"
#endif

#include <algorithm>
#include <cstring>
#include <iomanip>
#include <iostream>
#include <string>

#ifdef __has_include
# if __has_include(<version>)
#   include <version>
# endif
#endif

#define COMPILER_FEATURE_VALUE(value) #value
#define COMPILER_FEATURE_ENTRY(name) { #name, COMPILER_FEATURE_VALUE(name) },

#ifdef __has_cpp_attribute
# define COMPILER_ATTRIBUTE_VALUE_AS_STRING(s) #s
# define COMPILER_ATTRIBUTE_AS_NUMBER(x) COMPILER_ATTRIBUTE_VALUE_AS_STRING(x)
# define COMPILER_ATTRIBUTE_ENTRY(attr) 
  { #attr, COMPILER_ATTRIBUTE_AS_NUMBER(__has_cpp_attribute(attr)) },
#else
# define COMPILER_ATTRIBUTE_ENTRY(attr) { #attr, "_" },
#endif

// 更改这些选项以仅打印所需的信息。
static struct PrintOptions {
    constexpr static bool titles               = 1;
    constexpr static bool attributes           = 1;
    constexpr static bool general_features     = 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 sorted_by_value      = 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;
}   print;

struct CompilerFeature {
    CompilerFeature(const char* name = nullptr, const char* value = nullptr)
            : name(name), value(value) {}
    const char* name; const char* value;
};

static CompilerFeature cxx[] = {
        COMPILER_FEATURE_ENTRY(__cplusplus)
        COMPILER_FEATURE_ENTRY(__cpp_exceptions)
        COMPILER_FEATURE_ENTRY(__cpp_rtti)
#if 0
        COMPILER_FEATURE_ENTRY(__GNUC__)
COMPILER_FEATURE_ENTRY(__GNUC_MINOR__)
COMPILER_FEATURE_ENTRY(__GNUC_PATCHLEVEL__)
COMPILER_FEATURE_ENTRY(__GNUG__)
COMPILER_FEATURE_ENTRY(__clang__)
COMPILER_FEATURE_ENTRY(__clang_major__)
COMPILER_FEATURE_ENTRY(__clang_minor__)
COMPILER_FEATURE_ENTRY(__clang_patchlevel__)
#endif
};
static CompilerFeature cxx11[] = {
        COMPILER_FEATURE_ENTRY(__cpp_alias_templates)
        COMPILER_FEATURE_ENTRY(__cpp_attributes)
        COMPILER_FEATURE_ENTRY(__cpp_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_decltype)
        COMPILER_FEATURE_ENTRY(__cpp_delegating_constructors)
        COMPILER_FEATURE_ENTRY(__cpp_inheriting_constructors)
        COMPILER_FEATURE_ENTRY(__cpp_initializer_lists)
        COMPILER_FEATURE_ENTRY(__cpp_lambdas)
        COMPILER_FEATURE_ENTRY(__cpp_nsdmi)
        COMPILER_FEATURE_ENTRY(__cpp_range_based_for)
        COMPILER_FEATURE_ENTRY(__cpp_raw_strings)
        COMPILER_FEATURE_ENTRY(__cpp_ref_qualifiers)
        COMPILER_FEATURE_ENTRY(__cpp_rvalue_references)
        COMPILER_FEATURE_ENTRY(__cpp_static_assert)
        COMPILER_FEATURE_ENTRY(__cpp_threadsafe_static_init)
        COMPILER_FEATURE_ENTRY(__cpp_unicode_characters)
        COMPILER_FEATURE_ENTRY(__cpp_unicode_literals)
        COMPILER_FEATURE_ENTRY(__cpp_user_defined_literals)
        COMPILER_FEATURE_ENTRY(__cpp_variadic_templates)
};
static CompilerFeature cxx14[] = {
        COMPILER_FEATURE_ENTRY(__cpp_aggregate_nsdmi)
        COMPILER_FEATURE_ENTRY(__cpp_binary_literals)
        COMPILER_FEATURE_ENTRY(__cpp_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_decltype_auto)
        COMPILER_FEATURE_ENTRY(__cpp_generic_lambdas)
        COMPILER_FEATURE_ENTRY(__cpp_init_captures)
        COMPILER_FEATURE_ENTRY(__cpp_return_type_deduction)
        COMPILER_FEATURE_ENTRY(__cpp_sized_deallocation)
        COMPILER_FEATURE_ENTRY(__cpp_variable_templates)
};
static CompilerFeature cxx14lib[] = {
        COMPILER_FEATURE_ENTRY(__cpp_lib_chrono_udls)
        COMPILER_FEATURE_ENTRY(__cpp_lib_complex_udls)
        COMPILER_FEATURE_ENTRY(__cpp_lib_exchange_function)
        COMPILER_FEATURE_ENTRY(__cpp_lib_generic_associative_lookup)
        COMPILER_FEATURE_ENTRY(__cpp_lib_integer_sequence)
        COMPILER_FEATURE_ENTRY(__cpp_lib_integral_constant_callable)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_final)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_null_pointer)
        COMPILER_FEATURE_ENTRY(__cpp_lib_make_reverse_iterator)
        COMPILER_FEATURE_ENTRY(__cpp_lib_make_unique)
        COMPILER_FEATURE_ENTRY(__cpp_lib_null_iterators)
        COMPILER_FEATURE_ENTRY(__cpp_lib_quoted_string_io)
        COMPILER_FEATURE_ENTRY(__cpp_lib_result_of_sfinae)
        COMPILER_FEATURE_ENTRY(__cpp_lib_robust_nonmodifying_seq_ops)
        COMPILER_FEATURE_ENTRY(__cpp_lib_shared_timed_mutex)
        COMPILER_FEATURE_ENTRY(__cpp_lib_string_udls)
        COMPILER_FEATURE_ENTRY(__cpp_lib_transformation_trait_aliases)
        COMPILER_FEATURE_ENTRY(__cpp_lib_transparent_operators)
        COMPILER_FEATURE_ENTRY(__cpp_lib_tuple_element_t)
        COMPILER_FEATURE_ENTRY(__cpp_lib_tuples_by_type)
};

static CompilerFeature cxx17[] = {
        COMPILER_FEATURE_ENTRY(__cpp_aggregate_bases)
        COMPILER_FEATURE_ENTRY(__cpp_aligned_new)
        COMPILER_FEATURE_ENTRY(__cpp_capture_star_this)
        COMPILER_FEATURE_ENTRY(__cpp_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_deduction_guides)
        COMPILER_FEATURE_ENTRY(__cpp_enumerator_attributes)
        COMPILER_FEATURE_ENTRY(__cpp_fold_expressions)
        COMPILER_FEATURE_ENTRY(__cpp_guaranteed_copy_elision)
        COMPILER_FEATURE_ENTRY(__cpp_hex_float)
        COMPILER_FEATURE_ENTRY(__cpp_if_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_inheriting_constructors)
        COMPILER_FEATURE_ENTRY(__cpp_inline_variables)
        COMPILER_FEATURE_ENTRY(__cpp_namespace_attributes)
        COMPILER_FEATURE_ENTRY(__cpp_noexcept_function_type)
        COMPILER_FEATURE_ENTRY(__cpp_nontype_template_args)
        COMPILER_FEATURE_ENTRY(__cpp_nontype_template_parameter_auto)
        COMPILER_FEATURE_ENTRY(__cpp_range_based_for)
        COMPILER_FEATURE_ENTRY(__cpp_static_assert)
        COMPILER_FEATURE_ENTRY(__cpp_structured_bindings)
        COMPILER_FEATURE_ENTRY(__cpp_template_template_args)
        COMPILER_FEATURE_ENTRY(__cpp_variadic_using)
};
static CompilerFeature cxx17lib[] = {
        COMPILER_FEATURE_ENTRY(__cpp_lib_addressof_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_lib_allocator_traits_is_always_equal)
        COMPILER_FEATURE_ENTRY(__cpp_lib_any)
        COMPILER_FEATURE_ENTRY(__cpp_lib_apply)
        COMPILER_FEATURE_ENTRY(__cpp_lib_array_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_lib_as_const)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_is_always_lock_free)
        COMPILER_FEATURE_ENTRY(__cpp_lib_bool_constant)
        COMPILER_FEATURE_ENTRY(__cpp_lib_boyer_moore_searcher)
        COMPILER_FEATURE_ENTRY(__cpp_lib_byte)
        COMPILER_FEATURE_ENTRY(__cpp_lib_chrono)
        COMPILER_FEATURE_ENTRY(__cpp_lib_clamp)
        COMPILER_FEATURE_ENTRY(__cpp_lib_enable_shared_from_this)
        COMPILER_FEATURE_ENTRY(__cpp_lib_execution)
        COMPILER_FEATURE_ENTRY(__cpp_lib_filesystem)
        COMPILER_FEATURE_ENTRY(__cpp_lib_gcd_lcm)
        COMPILER_FEATURE_ENTRY(__cpp_lib_hardware_interference_size)
        COMPILER_FEATURE_ENTRY(__cpp_lib_has_unique_object_representations)
        COMPILER_FEATURE_ENTRY(__cpp_lib_hypot)
        COMPILER_FEATURE_ENTRY(__cpp_lib_incomplete_container_elements)
        COMPILER_FEATURE_ENTRY(__cpp_lib_invoke)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_aggregate)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_invocable)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_swappable)
        COMPILER_FEATURE_ENTRY(__cpp_lib_launder)
        COMPILER_FEATURE_ENTRY(__cpp_lib_logical_traits)
        COMPILER_FEATURE_ENTRY(__cpp_lib_make_from_tuple)
        COMPILER_FEATURE_ENTRY(__cpp_lib_map_try_emplace)
        COMPILER_FEATURE_ENTRY(__cpp_lib_math_special_functions)
        COMPILER_FEATURE_ENTRY(__cpp_lib_memory_resource)
        COMPILER_FEATURE_ENTRY(__cpp_lib_node_extract)
        COMPILER_FEATURE_ENTRY(__cpp_lib_nonmember_container_access)
        COMPILER_FEATURE_ENTRY(__cpp_lib_not_fn)
        COMPILER_FEATURE_ENTRY(__cpp_lib_optional)
        COMPILER_FEATURE_ENTRY(__cpp_lib_parallel_algorithm)
        COMPILER_FEATURE_ENTRY(__cpp_lib_raw_memory_algorithms)
        COMPILER_FEATURE_ENTRY(__cpp_lib_sample)
        COMPILER_FEATURE_ENTRY(__cpp_lib_scoped_lock)
        COMPILER_FEATURE_ENTRY(__cpp_lib_shared_mutex)
        COMPILER_FEATURE_ENTRY(__cpp_lib_shared_ptr_arrays)
        COMPILER_FEATURE_ENTRY(__cpp_lib_shared_ptr_weak_type)
        COMPILER_FEATURE_ENTRY(__cpp_lib_string_view)
        COMPILER_FEATURE_ENTRY(__cpp_lib_to_chars)
        COMPILER_FEATURE_ENTRY(__cpp_lib_transparent_operators)
        COMPILER_FEATURE_ENTRY(__cpp_lib_type_trait_variable_templates)
        COMPILER_FEATURE_ENTRY(__cpp_lib_uncaught_exceptions)
        COMPILER_FEATURE_ENTRY(__cpp_lib_unordered_map_try_emplace)
        COMPILER_FEATURE_ENTRY(__cpp_lib_variant)
        COMPILER_FEATURE_ENTRY(__cpp_lib_void_t)
};

static CompilerFeature cxx20[] = {
        COMPILER_FEATURE_ENTRY(__cpp_aggregate_paren_init)
        COMPILER_FEATURE_ENTRY(__cpp_char8_t)
        COMPILER_FEATURE_ENTRY(__cpp_concepts)
        COMPILER_FEATURE_ENTRY(__cpp_conditional_explicit)
        COMPILER_FEATURE_ENTRY(__cpp_consteval)
        COMPILER_FEATURE_ENTRY(__cpp_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_constexpr_dynamic_alloc)
        COMPILER_FEATURE_ENTRY(__cpp_constexpr_in_decltype)
        COMPILER_FEATURE_ENTRY(__cpp_constinit)
        COMPILER_FEATURE_ENTRY(__cpp_deduction_guides)
        COMPILER_FEATURE_ENTRY(__cpp_designated_initializers)
        COMPILER_FEATURE_ENTRY(__cpp_generic_lambdas)
        COMPILER_FEATURE_ENTRY(__cpp_impl_coroutine)
        COMPILER_FEATURE_ENTRY(__cpp_impl_destroying_delete)
        COMPILER_FEATURE_ENTRY(__cpp_impl_three_way_comparison)
        COMPILER_FEATURE_ENTRY(__cpp_init_captures)
        COMPILER_FEATURE_ENTRY(__cpp_modules)
        COMPILER_FEATURE_ENTRY(__cpp_nontype_template_args)
        COMPILER_FEATURE_ENTRY(__cpp_using_enum)
};
static CompilerFeature cxx20lib[] = {
        COMPILER_FEATURE_ENTRY(__cpp_lib_array_constexpr)
        COMPILER_FEATURE_ENTRY(__cpp_lib_assume_aligned)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_flag_test)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_float)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_lock_free_type_aliases)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_ref)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_shared_ptr)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_value_initialization)
        COMPILER_FEATURE_ENTRY(__cpp_lib_atomic_wait)
        COMPILER_FEATURE_ENTRY(__cpp_lib_barrier)
        COMPILER_FEATURE_ENTRY(__cpp_lib_bind_front)
        COMPILER_FEATURE_ENTRY(__cpp_lib_bit_cast)
        COMPILER_FEATURE_ENTRY(__cpp_lib_bitops)
        COMPILER_FEATURE_ENTRY(__cpp_lib_bounded_array_traits)
        COMPILER_FEATURE_ENTRY(__cpp_lib_char8_t)
        COMPILER_FEATURE_ENTRY(__cpp_lib_chrono)
        COMPILER_FEATURE_ENTRY(__cpp_lib_concepts)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_algorithms)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_complex)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_dynamic_alloc)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_functional)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_iterator)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_memory)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_numeric)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_string)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_string_view)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_tuple)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_utility)
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_vector)
        COMPILER_FEATURE_ENTRY(__cpp_lib_coroutine)
        COMPILER_FEATURE_ENTRY(__cpp_lib_destroying_delete)
        COMPILER_FEATURE_ENTRY(__cpp_lib_endian)
        COMPILER_FEATURE_ENTRY(__cpp_lib_erase_if)
        COMPILER_FEATURE_ENTRY(__cpp_lib_execution)
        COMPILER_FEATURE_ENTRY(__cpp_lib_format)
        COMPILER_FEATURE_ENTRY(__cpp_lib_generic_unordered_lookup)
        COMPILER_FEATURE_ENTRY(__cpp_lib_int_pow2)
        COMPILER_FEATURE_ENTRY(__cpp_lib_integer_comparison_functions)
        COMPILER_FEATURE_ENTRY(__cpp_lib_interpolate)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_constant_evaluated)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_layout_compatible)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_nothrow_convertible)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_pointer_interconvertible)
        COMPILER_FEATURE_ENTRY(__cpp_lib_jthread)
        COMPILER_FEATURE_ENTRY(__cpp_lib_latch)
        COMPILER_FEATURE_ENTRY(__cpp_lib_list_remove_return_type)
        COMPILER_FEATURE_ENTRY(__cpp_lib_math_constants)
        COMPILER_FEATURE_ENTRY(__cpp_lib_polymorphic_allocator)
        COMPILER_FEATURE_ENTRY(__cpp_lib_ranges)
        COMPILER_FEATURE_ENTRY(__cpp_lib_remove_cvref)
        COMPILER_FEATURE_ENTRY(__cpp_lib_semaphore)
        COMPILER_FEATURE_ENTRY(__cpp_lib_shared_ptr_arrays)
        COMPILER_FEATURE_ENTRY(__cpp_lib_shift)
        COMPILER_FEATURE_ENTRY(__cpp_lib_smart_ptr_for_overwrite)
        COMPILER_FEATURE_ENTRY(__cpp_lib_source_location)
        COMPILER_FEATURE_ENTRY(__cpp_lib_span)
        COMPILER_FEATURE_ENTRY(__cpp_lib_ssize)
        COMPILER_FEATURE_ENTRY(__cpp_lib_starts_ends_with)
        COMPILER_FEATURE_ENTRY(__cpp_lib_string_view)
        COMPILER_FEATURE_ENTRY(__cpp_lib_syncbuf)
        COMPILER_FEATURE_ENTRY(__cpp_lib_three_way_comparison)
        COMPILER_FEATURE_ENTRY(__cpp_lib_to_address)
        COMPILER_FEATURE_ENTRY(__cpp_lib_to_array)
        COMPILER_FEATURE_ENTRY(__cpp_lib_type_identity)
        COMPILER_FEATURE_ENTRY(__cpp_lib_unwrap_ref)
};

static CompilerFeature cxx23[] = {
//< 继续填充
        COMPILER_FEATURE_ENTRY(__cpp_if_consteval)
        COMPILER_FEATURE_ENTRY(__cpp_size_t_suffix)
};
static CompilerFeature cxx23lib[] = {
//< 继续填充
        COMPILER_FEATURE_ENTRY(__cpp_lib_constexpr_typeinfo)
        COMPILER_FEATURE_ENTRY(__cpp_lib_invoke_r)
        COMPILER_FEATURE_ENTRY(__cpp_lib_is_scoped_enum)
        COMPILER_FEATURE_ENTRY(__cpp_lib_stacktrace)
        COMPILER_FEATURE_ENTRY(__cpp_lib_stdatomic_h)
        COMPILER_FEATURE_ENTRY(__cpp_lib_string_contains)
        COMPILER_FEATURE_ENTRY(__cpp_lib_to_underlying)
        COMPILER_FEATURE_ENTRY(__cpp_lib_variant)
};

static CompilerFeature attributes[] = {
        COMPILER_ATTRIBUTE_ENTRY(carries_dependency)
        COMPILER_ATTRIBUTE_ENTRY(deprecated)
        COMPILER_ATTRIBUTE_ENTRY(fallthrough)
        COMPILER_ATTRIBUTE_ENTRY(likely)
        COMPILER_ATTRIBUTE_ENTRY(maybe_unused)
        COMPILER_ATTRIBUTE_ENTRY(nodiscard)
        COMPILER_ATTRIBUTE_ENTRY(noreturn)
        COMPILER_ATTRIBUTE_ENTRY(no_unique_address)
        COMPILER_ATTRIBUTE_ENTRY(unlikely)
};

constexpr bool is_feature_supported(const CompilerFeature& x) {
    return x.value[0] != '_' && x.value[0] != '0' ;
}

inline void print_compiler_feature(const CompilerFeature& x) {
    constexpr static int max_name_length = 44; //< Update if necessary
    std::string value{ is_feature_supported(x) ? x.value : "------" };
    if (value.back() == 'L') value.pop_back(); //~ 201603L -> 201603
    // value.insert(4, 1, '-'); //~ 201603 -> 2016-03
    if ( (print.supported_features && is_feature_supported(x))
         or (print.unsupported_features && !is_feature_supported(x))) {
        std::cout << std::left << std::setw(max_name_length)
                  << x.name << " " << value << '
';
    }
}

template<std::size_t N>
inline void show(char const* title, CompilerFeature (&features)[N]) {
    if (print.titles) {
        std::cout << '
' << std::left << title << '
';
    }
    if (print.sorted_by_value) {
        std::sort(std::begin(features), std::end(features),
                  [](CompilerFeature const& lhs, CompilerFeature const& rhs) {
                      return std::strcmp(lhs.value, rhs.value) < 0;
                  });
    }
    for (const CompilerFeature& x : features) {
        print_compiler_feature(x);
    }
}

int main() {
    if (print.general_features) show("C++ GENERAL", cxx);
    if (print.cxx11 && print.core_features) show("C++11 CORE", cxx11);
    if (print.cxx14 && print.core_features) show("C++14 CORE", cxx14);
    if (print.cxx14 && print.lib_features ) show("C++14 LIB" , cxx14lib);
    if (print.cxx17 && print.core_features) show("C++17 CORE", cxx17);
    if (print.cxx17 && print.lib_features ) show("C++17 LIB" , cxx17lib);
    if (print.cxx20 && print.core_features) show("C++20 CORE", cxx20);
    if (print.cxx20 && print.lib_features ) show("C++20 LIB" , cxx20lib);
    if (print.cxx23 && print.core_features) show("C++23 CORE", cxx23);
    if (print.cxx23 && print.lib_features ) show("C++23 LIB" , cxx23lib);
    if (print.attributes) show("ATTRIBUTES", attributes);
}

测试结果

1) Visual Studio 2022

以下是Visual Studio 2022的测试结果,支持的feature比较全。

  1. 需要在项目属性中选择最新的C++版本。需要选择“预览”选项,C++23的feature才会支持。
    在这里插入图片描述

  2. vs编译器中__cplusplus对应值是199711,测试程序开头(前3行)的监测不能通过,可以注释掉或者修改第一行的数值。
    gcc或者clang都没可以直接测试通过。

  3. 测试结果中显示对标准中attributes支持不好,在代码中实际测试大部分attributes都是支持的。
    可能是对测试宏的检测方式不兼容,这个问题抽空调查一下(todo)。

C++ GENERAL
__cplusplus                                  199711
__cpp_exceptions                             199711
__cpp_rtti                                   199711

C++11 CORE
__cpp_alias_templates                        200704
__cpp_attributes                             200809
__cpp_constexpr                              202002
__cpp_decltype                               200707
__cpp_delegating_constructors                200604
__cpp_inheriting_constructors                201511
__cpp_initializer_lists                      200806
__cpp_lambdas                                200907
__cpp_nsdmi                                  200809
__cpp_range_based_for                        201603
__cpp_raw_strings                            200710
__cpp_ref_qualifiers                         200710
__cpp_rvalue_references                      200610
__cpp_static_assert                          201411
__cpp_threadsafe_static_init                 200806
__cpp_unicode_characters                     200704
__cpp_unicode_literals                       200710
__cpp_user_defined_literals                  200809
__cpp_variadic_templates                     200704

C++14 CORE
__cpp_aggregate_nsdmi                        201304
__cpp_binary_literals                        201304
__cpp_constexpr                              202002
__cpp_decltype_auto                          201304
__cpp_generic_lambdas                        201707
__cpp_init_captures                          201803
__cpp_return_type_deduction                  201304
__cpp_sized_deallocation                     201309
__cpp_variable_templates                     201304

C++14 LIB
__cpp_lib_chrono_udls                        201304
__cpp_lib_complex_udls                       201309
__cpp_lib_exchange_function                  201304
__cpp_lib_generic_associative_lookup         201304
__cpp_lib_integer_sequence                   201304
__cpp_lib_integral_constant_callable         201304
__cpp_lib_is_final                           201402
__cpp_lib_is_null_pointer                    201309
__cpp_lib_make_reverse_iterator              201402
__cpp_lib_make_unique                        201304
__cpp_lib_null_iterators                     201304
__cpp_lib_quoted_string_io                   201304
__cpp_lib_result_of_sfinae                   201210
__cpp_lib_robust_nonmodifying_seq_ops        201304
__cpp_lib_shared_timed_mutex                 201402
__cpp_lib_string_udls                        201304
__cpp_lib_transformation_trait_aliases       201304
__cpp_lib_transparent_operators              201510
__cpp_lib_tuple_element_t                    201402
__cpp_lib_tuples_by_type                     201304

C++17 CORE
__cpp_aggregate_bases                        201603
__cpp_aligned_new                            201606
__cpp_capture_star_this                      201603
__cpp_constexpr                              202002
__cpp_deduction_guides                       201907
__cpp_enumerator_attributes                  201411
__cpp_fold_expressions                       201603
__cpp_guaranteed_copy_elision                201606
__cpp_hex_float                              201603
__cpp_if_constexpr                           201606
__cpp_inheriting_constructors                201511
__cpp_inline_variables                       201606
__cpp_namespace_attributes                   201411
__cpp_noexcept_function_type                 201510
__cpp_nontype_template_args                  201911
__cpp_nontype_template_parameter_auto        201606
__cpp_range_based_for                        201603
__cpp_static_assert                          201411
__cpp_structured_bindings                    201606
__cpp_template_template_args                 201611
__cpp_variadic_using                         201611

C++17 LIB
__cpp_lib_addressof_constexpr                201603
__cpp_lib_allocator_traits_is_always_equal   201411
__cpp_lib_any                                201606
__cpp_lib_apply                              201603
__cpp_lib_array_constexpr                    201811
__cpp_lib_as_const                           201510
__cpp_lib_atomic_is_always_lock_free         201603
__cpp_lib_bool_constant                      201505
__cpp_lib_boyer_moore_searcher               201603
__cpp_lib_byte                               201603
__cpp_lib_chrono                             201907
__cpp_lib_clamp                              201603
__cpp_lib_enable_shared_from_this            201603
__cpp_lib_execution                          201902
__cpp_lib_filesystem                         201703
__cpp_lib_gcd_lcm                            201606
__cpp_lib_hardware_interference_size         201703
__cpp_lib_has_unique_object_representations  201606
__cpp_lib_hypot                              201603
__cpp_lib_incomplete_container_elements      201505
__cpp_lib_invoke                             201411
__cpp_lib_is_aggregate                       201703
__cpp_lib_is_invocable                       201703
__cpp_lib_is_swappable                       201603
__cpp_lib_launder                            201606
__cpp_lib_logical_traits                     201510
__cpp_lib_make_from_tuple                    201606
__cpp_lib_map_try_emplace                    201411
__cpp_lib_math_special_functions             201603
__cpp_lib_memory_resource                    201603
__cpp_lib_node_extract                       201606
__cpp_lib_nonmember_container_access         201411
__cpp_lib_not_fn                             201603
__cpp_lib_optional                           202110
__cpp_lib_parallel_algorithm                 201603
__cpp_lib_raw_memory_algorithms              201606
__cpp_lib_sample                             201603
__cpp_lib_scoped_lock                        201703
__cpp_lib_shared_mutex                       201505
__cpp_lib_shared_ptr_arrays                  201707
__cpp_lib_shared_ptr_weak_type               201606
__cpp_lib_string_view                        201803
__cpp_lib_to_chars                           201611
__cpp_lib_transparent_operators              201510
__cpp_lib_type_trait_variable_templates      201510
__cpp_lib_uncaught_exceptions                201411
__cpp_lib_unordered_map_try_emplace          201411
__cpp_lib_variant                            202106
__cpp_lib_void_t                             201411

C++20 CORE
__cpp_aggregate_paren_init                   201902
__cpp_char8_t                                202207
__cpp_concepts                               202002
__cpp_conditional_explicit                   201806
__cpp_consteval                              201811
__cpp_constexpr                              202002
__cpp_constexpr_dynamic_alloc                201907
__cpp_constexpr_in_decltype                  ------
__cpp_constinit                              201907
__cpp_deduction_guides                       201907
__cpp_designated_initializers                201707
__cpp_generic_lambdas                        201707
__cpp_impl_coroutine                         201902
__cpp_impl_destroying_delete                 201806
__cpp_impl_three_way_comparison              201907
__cpp_init_captures                          201803
__cpp_modules                                201907
__cpp_nontype_template_args                  201911
__cpp_using_enum                             201907

C++20 LIB
__cpp_lib_array_constexpr                    201811
__cpp_lib_assume_aligned                     201811
__cpp_lib_atomic_flag_test                   201907
__cpp_lib_atomic_float                       201711
__cpp_lib_atomic_lock_free_type_aliases      201907
__cpp_lib_atomic_ref                         201806
__cpp_lib_atomic_shared_ptr                  201711
__cpp_lib_atomic_value_initialization        201911
__cpp_lib_atomic_wait                        201907
__cpp_lib_barrier                            201907
__cpp_lib_bind_front                         201907
__cpp_lib_bit_cast                           201806
__cpp_lib_bitops                             201907
__cpp_lib_bounded_array_traits               201902
__cpp_lib_char8_t                            201907
__cpp_lib_chrono                             201907
__cpp_lib_concepts                           202002
__cpp_lib_constexpr_algorithms               201806
__cpp_lib_constexpr_complex                  201711
__cpp_lib_constexpr_dynamic_alloc            201907
__cpp_lib_constexpr_functional               201907
__cpp_lib_constexpr_iterator                 201811
__cpp_lib_constexpr_memory                   202202
__cpp_lib_constexpr_numeric                  201911
__cpp_lib_constexpr_string                   201907
__cpp_lib_constexpr_string_view              201811
__cpp_lib_constexpr_tuple                    201811
__cpp_lib_constexpr_utility                  201811
__cpp_lib_constexpr_vector                   201907
__cpp_lib_coroutine                          201902
__cpp_lib_destroying_delete                  201806
__cpp_lib_endian                             201907
__cpp_lib_erase_if                           202002
__cpp_lib_execution                          201902
__cpp_lib_format                             202207
__cpp_lib_generic_unordered_lookup           201811
__cpp_lib_int_pow2                           202002
__cpp_lib_integer_comparison_functions       202002
__cpp_lib_interpolate                        201902
__cpp_lib_is_constant_evaluated              201811
__cpp_lib_is_layout_compatible               201907
__cpp_lib_is_nothrow_convertible             201806
__cpp_lib_is_pointer_interconvertible        201907
__cpp_lib_jthread                            201911
__cpp_lib_latch                              201907
__cpp_lib_list_remove_return_type            201806
__cpp_lib_math_constants                     201907
__cpp_lib_polymorphic_allocator              201902
__cpp_lib_ranges                             202207
__cpp_lib_remove_cvref                       201711
__cpp_lib_semaphore                          201907
__cpp_lib_shared_ptr_arrays                  201707
__cpp_lib_shift                              202202
__cpp_lib_smart_ptr_for_overwrite            202002
__cpp_lib_source_location                    201907
__cpp_lib_span                               202002
__cpp_lib_ssize                              201902
__cpp_lib_starts_ends_with                   201711
__cpp_lib_string_view                        201803
__cpp_lib_syncbuf                            201803
__cpp_lib_three_way_comparison               201907
__cpp_lib_to_address                         201711
__cpp_lib_to_array                           201907
__cpp_lib_type_identity                      201806
__cpp_lib_unwrap_ref                         201811

C++23 CORE
__cpp_if_consteval                           ------
__cpp_size_t_suffix                          ------

C++23 LIB
__cpp_lib_constexpr_typeinfo                 202106
__cpp_lib_invoke_r                           202106
__cpp_lib_is_scoped_enum                     202011
__cpp_lib_stacktrace                         202011
__cpp_lib_stdatomic_h                        202011
__cpp_lib_string_contains                    202011
__cpp_lib_to_underlying                      202102
__cpp_lib_variant                            202106

ATTRIBUTES
carries_dependency                           ------
deprecated                                   ------
fallthrough                                  ------
likely                                       ------
maybe_unused                                 ------
nodiscard                                    ------
noreturn                                     ------
no_unique_address                            ------
unlikely                                     ------

2) g++ -12 (on Ubuntu 22.04)

以下是gcc的测试结果。从结果看对C++的支持也比较全面,和vs2022对比有少量差异。最后附上一个二者的对比。

  1. 编译时需要通过参数(–std)指定C++版本:
$ g++-12 -std=c++23 main.cpp -o main
  1. Ubuntu 22.04上默认是g++ -11,升级成g++ -12后进行测试(有少量更新)。
C++ GENERAL
__cplusplus                                  202100
__cpp_exceptions                             199711
__cpp_rtti                                   199711

C++11 CORE
__cpp_alias_templates                        200704
__cpp_attributes                             200809
__cpp_constexpr                              202110
__cpp_decltype                               200707
__cpp_delegating_constructors                200604
__cpp_inheriting_constructors                201511
__cpp_initializer_lists                      200806
__cpp_lambdas                                200907
__cpp_nsdmi                                  200809
__cpp_range_based_for                        201603
__cpp_raw_strings                            200710
__cpp_ref_qualifiers                         200710
__cpp_rvalue_references                      200610
__cpp_static_assert                          201411
__cpp_threadsafe_static_init                 200806
__cpp_unicode_characters                     201411
__cpp_unicode_literals                       200710
__cpp_user_defined_literals                  200809
__cpp_variadic_templates                     200704

C++14 CORE
__cpp_aggregate_nsdmi                        201304
__cpp_binary_literals                        201304
__cpp_constexpr                              202110
__cpp_decltype_auto                          201304
__cpp_generic_lambdas                        201707
__cpp_init_captures                          201803
__cpp_return_type_deduction                  201304
__cpp_sized_deallocation                     201309
__cpp_variable_templates                     201304

C++14 LIB
__cpp_lib_chrono_udls                        201304
__cpp_lib_complex_udls                       201309
__cpp_lib_exchange_function                  201304
__cpp_lib_generic_associative_lookup         201304
__cpp_lib_integer_sequence                   201304
__cpp_lib_integral_constant_callable         201304
__cpp_lib_is_final                           201402
__cpp_lib_is_null_pointer                    201309
__cpp_lib_make_reverse_iterator              201402
__cpp_lib_make_unique                        201304
__cpp_lib_null_iterators                     201304
__cpp_lib_quoted_string_io                   201304
__cpp_lib_result_of_sfinae                   201210
__cpp_lib_robust_nonmodifying_seq_ops        201304
__cpp_lib_shared_timed_mutex                 201402
__cpp_lib_string_udls                        201304
__cpp_lib_transformation_trait_aliases       201304
__cpp_lib_transparent_operators              201510
__cpp_lib_tuple_element_t                    201402
__cpp_lib_tuples_by_type                     201304

C++17 CORE
__cpp_aggregate_bases                        201603
__cpp_aligned_new                            201606
__cpp_capture_star_this                      201603
__cpp_constexpr                              202110
__cpp_deduction_guides                       201907
__cpp_enumerator_attributes                  201411
__cpp_fold_expressions                       201603
__cpp_guaranteed_copy_elision                201606
__cpp_hex_float                              201603
__cpp_if_constexpr                           201606
__cpp_inheriting_constructors                201511
__cpp_inline_variables                       201606
__cpp_namespace_attributes                   201411
__cpp_noexcept_function_type                 201510
__cpp_nontype_template_args                  201911
__cpp_nontype_template_parameter_auto        201606
__cpp_range_based_for                        201603
__cpp_static_assert                          201411
__cpp_structured_bindings                    201606
__cpp_template_template_args                 201611
__cpp_variadic_using                         201611

C++17 LIB
__cpp_lib_addressof_constexpr                201603
__cpp_lib_allocator_traits_is_always_equal   201411
__cpp_lib_any                                201606
__cpp_lib_apply                              201603
__cpp_lib_array_constexpr                    201811
__cpp_lib_as_const                           201510
__cpp_lib_atomic_is_always_lock_free         201603
__cpp_lib_bool_constant                      201505
__cpp_lib_boyer_moore_searcher               201603
__cpp_lib_byte                               201603
__cpp_lib_chrono                             201611
__cpp_lib_clamp                              201603
__cpp_lib_enable_shared_from_this            201603
__cpp_lib_execution                          201902
__cpp_lib_filesystem                         201703
__cpp_lib_gcd_lcm                            201606
__cpp_lib_hardware_interference_size         201703
__cpp_lib_has_unique_object_representations  201606
__cpp_lib_hypot                              201603
__cpp_lib_incomplete_container_elements      201505
__cpp_lib_invoke                             201411
__cpp_lib_is_aggregate                       201703
__cpp_lib_is_invocable                       201703
__cpp_lib_is_swappable                       201603
__cpp_lib_launder                            201606
__cpp_lib_logical_traits                     201510
__cpp_lib_make_from_tuple                    201606
__cpp_lib_map_try_emplace                    201411
__cpp_lib_math_special_functions             201603
__cpp_lib_memory_resource                    201603
__cpp_lib_node_extract                       201606
__cpp_lib_nonmember_container_access         201411
__cpp_lib_not_fn                             201603
__cpp_lib_optional                           202110
__cpp_lib_parallel_algorithm                 201603
__cpp_lib_raw_memory_algorithms              201606
__cpp_lib_sample                             201603
__cpp_lib_scoped_lock                        201703
__cpp_lib_shared_mutex                       201505
__cpp_lib_shared_ptr_arrays                  201707
__cpp_lib_shared_ptr_weak_type               201606
__cpp_lib_string_view                        201803
__cpp_lib_to_chars                           201611
__cpp_lib_transparent_operators              201510
__cpp_lib_type_trait_variable_templates      201510
__cpp_lib_uncaught_exceptions                201411
__cpp_lib_unordered_map_try_emplace          201411
__cpp_lib_variant                            202106
__cpp_lib_void_t                             201411

C++20 CORE
__cpp_aggregate_paren_init                   201902
__cpp_char8_t                                201811
__cpp_concepts                               202002
__cpp_conditional_explicit                   201806
__cpp_consteval                              201811
__cpp_constexpr                              202110
__cpp_constexpr_dynamic_alloc                201907
__cpp_constexpr_in_decltype                  201711
__cpp_constinit                              201907
__cpp_deduction_guides                       201907
__cpp_designated_initializers                201707
__cpp_generic_lambdas                        201707
__cpp_impl_coroutine                         201902
__cpp_impl_destroying_delete                 201806
__cpp_impl_three_way_comparison              201907
__cpp_init_captures                          201803
__cpp_modules                                ------
__cpp_nontype_template_args                  201911
__cpp_using_enum                             201907

C++20 LIB
__cpp_lib_array_constexpr                    201811
__cpp_lib_assume_aligned                     201811
__cpp_lib_atomic_flag_test                   201907
__cpp_lib_atomic_float                       201711
__cpp_lib_atomic_lock_free_type_aliases      ------
__cpp_lib_atomic_ref                         201806
__cpp_lib_atomic_shared_ptr                  201711
__cpp_lib_atomic_value_initialization        201911
__cpp_lib_atomic_wait                        201907
__cpp_lib_barrier                            201907
__cpp_lib_bind_front                         201907
__cpp_lib_bit_cast                           201806
__cpp_lib_bitops                             201907
__cpp_lib_bounded_array_traits               201902
__cpp_lib_char8_t                            201907
__cpp_lib_chrono                             201611
__cpp_lib_concepts                           202002
__cpp_lib_constexpr_algorithms               201806
__cpp_lib_constexpr_complex                  201711
__cpp_lib_constexpr_dynamic_alloc            201907
__cpp_lib_constexpr_functional               201907
__cpp_lib_constexpr_iterator                 201811
__cpp_lib_constexpr_memory                   202202
__cpp_lib_constexpr_numeric                  201911
__cpp_lib_constexpr_string                   201907
__cpp_lib_constexpr_string_view              201811
__cpp_lib_constexpr_tuple                    201811
__cpp_lib_constexpr_utility                  201811
__cpp_lib_constexpr_vector                   201907
__cpp_lib_coroutine                          201902
__cpp_lib_destroying_delete                  201806
__cpp_lib_endian                             201907
__cpp_lib_erase_if                           202002
__cpp_lib_execution                          201902
__cpp_lib_format                             ------
__cpp_lib_generic_unordered_lookup           201811
__cpp_lib_int_pow2                           202002
__cpp_lib_integer_comparison_functions       202002
__cpp_lib_interpolate                        201902
__cpp_lib_is_constant_evaluated              201811
__cpp_lib_is_layout_compatible               201907
__cpp_lib_is_nothrow_convertible             201806
__cpp_lib_is_pointer_interconvertible        201907
__cpp_lib_jthread                            201911
__cpp_lib_latch                              201907
__cpp_lib_list_remove_return_type            201806
__cpp_lib_math_constants                     201907
__cpp_lib_polymorphic_allocator              201902
__cpp_lib_ranges                             202110
__cpp_lib_remove_cvref                       201711
__cpp_lib_semaphore                          201907
__cpp_lib_shared_ptr_arrays                  201707
__cpp_lib_shift                              201806
__cpp_lib_smart_ptr_for_overwrite            202002
__cpp_lib_source_location                    201907
__cpp_lib_span                               202002
__cpp_lib_ssize                              201902
__cpp_lib_starts_ends_with                   201711
__cpp_lib_string_view                        201803
__cpp_lib_syncbuf                            201803
__cpp_lib_three_way_comparison               201907
__cpp_lib_to_address                         201711
__cpp_lib_to_array                           201907
__cpp_lib_type_identity                      201806
__cpp_lib_unwrap_ref                         201811

C++23 CORE
__cpp_if_consteval                           202106
__cpp_size_t_suffix                          202011

C++23 LIB
__cpp_lib_constexpr_typeinfo                 202106
__cpp_lib_invoke_r                           202106
__cpp_lib_is_scoped_enum                     202011
__cpp_lib_stacktrace                         ------
__cpp_lib_stdatomic_h                        202011
__cpp_lib_string_contains                    202011
__cpp_lib_to_underlying                      202102
__cpp_lib_variant                            202106

ATTRIBUTES
carries_dependency                           ------
deprecated                                   201309
fallthrough                                  201603
likely                                       201803
maybe_unused                                 201603
nodiscard                                    201907
noreturn                                     200809
no_unique_address                            201803
unlikely                                     201803

3) Visual Studio 2022 vs. g++ -12

在这里插入图片描述

风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。