Conformidad del lenguaje Microsoft C/C++ por versión de Visual Studio

Actualmente, se sigue trabajando en la conformidad con los estándares del compilador de Microsoft C/C++ en Visual Studio (MSVC). Este es un resumen del estándar ISO del lenguaje C y C++ y la conformidad de la biblioteca de la versión de Visual Studio. El nombre de cada una de las características del compilador de C++ y de la biblioteca estándar vincula al documento de propuesta del estándar ISO para C++ que describe la característica, si hubiera alguno disponible en el momento de la publicación. La columna Compatible muestra la versión de Visual Studio en la que aparece por primera vez la compatibilidad de la característica.

Para más información sobre las mejoras de conformidad, vea Mejoras de conformidad de C++ en Visual Studio. Para obtener una lista de otros cambios, consulte Novedades de C++ en Visual Studio. Para conocer los cambios de conformidad en versiones anteriores, consulte Historial de cambios en Visual C++ 2003-2015 y Novedades de Visual C++ de 2003 a 2015. Para mantenerse al tanto de las noticias actuales del equipo de C++, visite el blog del equipo de C++.

Nota

No existen cambios importantes binarios entre Visual Studio 2015, Visual Studio 2017 y Visual Studio 2019. Para más información, consulte Compatibilidad binaria de C++ entre Visual Studio 2015, 2017 y 2019.

Características del compilador de C++

Característica Compatible
Características principales del lenguaje C++03/11 Compatible
 Todo lo demás VS 2015 A
 Búsqueda de nombres en dos fases VS 2017 15.7 B
N2634 Expression SFINAE VS 2017 15.7
N1653 C99 preprocessor VS 2019 16.6 C
Características principales del lenguaje C++14 Compatible
N3323 Tweaked wording for contextual conversions VS 2013
N3472 Binary literals VS 2015
N3638 auto and decltype(auto) return types VS 2015
N3648 init-captures VS 2015
N3649 Generic lambdas VS 2015
N3760 [[deprecated]] attribute VS 2015
N3778 Sized deallocation VS 2015
N3781 Digit separators VS 2015
N3651 Variable templates VS 2015.2
N3652 Extended constexpr VS 2017 15.0
N3653 Default member initializers for aggregates VS 2017 15.0
Características principales del lenguaje C++17 Compatible
N4086 Removing trigraphs VS 2010 14
N3922 New rules for auto with braced-init-lists VS 2015 14
N4051 typename in template template-parameters VS 2015 14
N4266 Attributes for namespaces and enumerators VS 2015 14
N4267 u8 character literals VS 2015 14
N4230 Nested namespace definitions VS 2015.3 17
N3928 Terse static_assert VS 2017 15.0 17
P0184R0 Generalized range-based for-loops VS 2017 15.0 14
P0188R1 [[fallthrough]] attribute VS 2017 15.0 17
P0001R1 Removing the register keyword VS 2017 15.3 17
P0002R1 Removing operator++ for bool VS 2017 15.3 17
P0018R3 Capturing *this by value VS 2017 15.3 17
P0028R4 Using attribute namespaces without repetition VS 2017 15.3 17
P0061R1 __has_include VS 2017 15.3 14
P0138R2 Direct-list-init of fixed enums from integers VS 2017 15.3 17
P0170R1 constexpr lambdas VS 2017 15.3 17
P0189R1 [[nodiscard]] attribute VS 2017 15.3 17
P0212R1 [[maybe_unused]] attribute VS 2017 15.3 17
P0217R3 Structured bindings VS 2017 15.3 17
P0292R2 constexpr if-statements VS 2017 15.3 D
P0305R1 Selection statements with initializers VS 2017 15.3 17
P1381R1 Reference capture of structured bindings VS 2017 15.3 17
P0245R1 Hexfloat literals VS 2017 15.5 17
N4268 Allowing more non-type template args VS 2017 15.5 17
N4295 Fold expressions VS 2017 15.5 17
P0003R5 Removing dynamic-exception-specifications VS 2017 15.5 17
P0012R1 Adding noexcept to the type system VS 2017 15.5 17
P0035R4 Over-aligned dynamic memory allocation VS 2017 15.5 17
P0386R2 Inline variables VS 2017 15.5 17
P0522R0 Matching template template-parameters to compatible arguments VS 2017 15.5 17
P0036R0 Removing some empty unary folds VS 2017 15.5 17
N4261 Fixing qualification conversions VS 2017 15.7 17
P0017R1 Extended aggregate initialization VS 2017 15.7 17
P0091R3 Template argument deduction for class templates
P0512R0 Class template argument deduction issues
VS 2017 15.7 17
P0127R2 Declaring non-type template parameters with auto VS 2017 15.7 17
P0135R1 Guaranteed copy elision VS 2017 15.6
P0136R1 Rewording inheriting constructors VS 2017 15.7 17
P0137R1 std::launder VS 2017 15.7 17
P0145R3 Refining expression evaluation order
P0400R0 Order of evaluation of function arguments
VS 2017 15.7 17
P0195R2 Pack expansions in using-declarations VS 2017 15.7 17
P0283R2 Ignoring unrecognized attributes VS 2015 14
Características principales del lenguaje C++17 (informes de defectos) Compatible
P0702R1 Fixing class template argument deduction for initializer-list ctors VS 2017 15.7 17
P0961R1 Relaxing the structured bindings customization point finding rules VS 2019 16.0 17
P0969R0 Allowing structured bindings to accessible members VS 2019 16.0 17
P0588R1 Simplifying implicit lambda capture VS 2019 16.4 17
P1771R1 [[nodiscard]] for constructors VS 2019 16.4 17
P1825R0 Merged wording for P0527R1 and P1155R3, more implicit moves VS 2019 16.4 17
P0929R2 Checking for abstract class types VS 2019 16.5 17
P0962R1 Relaxing the range-for loop customization point finding rules VS 2019 16.5 17
P0859R0 CWG 1581: When are constexpr member functions defined Parcial en VS 2019 16.7 E
P1009R2 Array size deduction in new-expressions VS 2019 16.7 17
P1286R2 Contra CWG DR1778 VS 2019 16.8 17
Características principales del lenguaje C++20 Compatible
P0641R2 const mismatch with defaulted copy constructor VS 2015 14
P0704R1 Fixing const lvalue ref-qualified pointers to members VS 2015 14
P1041R4 Make char16_t/char32_t string literals be UTF-16/32 VS 2015 14
P1330R0 Changing the active member of a union inside constexpr VS 2017 15.0 14
P0972R0 noexcept For <chrono> zero(), min(), max() VS 2017 15.7 14
P0515R3 Three-way (spaceship) comparison operator <=> VS 2019 16.0 20
P0941R2 Feature-test macros VS 2019 16.0 14
P1008R1 Prohibiting aggregates with user-declared constructors VS 2019 16.0 20
P0329R4 Designated initialization VS 2019 16.1 20
P0846R0 ADL and function templates that are not visible VS 2019 16.1 20
P0409R2 Allowing lambda-capture [=, this] VS 2019 16.2 20
P0428R2 Familiar template syntax for generic lambdas VS 2019 16.2 20
P0624R2 Default constructible and assignable stateless lambdas VS 2019 16.2 20
P0780R2 Allowing pack expansion in lambda init-capture VS 2019 16.2 20
P0806R2 Deprecate implicit capture of this via [=] VS 2019 16.2 20
P1120R0 Consistency improvements for <=> and other comparison operators VS 2019 16.2 20
P1185R2 <=> != == VS 2019 16.2 20
P0734R0 Concepts VS 2019 16.3 20
P0857R0 Fixing functionality gaps in constraints VS 2019 16.3 20
P1084R2 Today's return-type-requirements are insufficient VS 2019 16.3 20
P0892R2 Conditional explicit VS 2019 16.4 20
P1091R3 Extending structured bindings to be more like variable declarations VS 2019 16.4 20
P1099R5 Using enum VS 2019 16.4 20
P1186R3 When do you actually use <=> VS 2019 16.4 20
P1630R1 Spaceship needs a tune-up VS 2019 16.4 20
P0306R4 Adding __VA_OPT__ for comma omission and comma deletion VS 2019 16.5 20
P0614R1 Range-based for-loops with initializers VS 2019 16.5 20
P0683R1 Default member initializers for bit-fields VS 2019 16.5 20
P1002R1 try-catch blocks in constexpr functions VS 2019 16.5 20
P1161R3 Deprecate uses of the comma operator in subscripting expressions VS 2019 16.5 20
P1301R4 [[nodiscard("message")]] VS 2019 16.5 20
P1703R1 Recognizing header unit imports requires full preprocessing VS 2019 16.5 20
P1946R0 Allow defaulting comparisons by value VS 2019 16.5 20
P0479R5 [[likely]] and [[unlikely]] attributes VS 2019 16.6 20
P0692R1 Relaxing access checking on specializations VS 2019 16.6 14
P0732R2 Class types in non-type template parameters VS 2019 16.6 20
P1139R2 Address wording issues related to ISO 10646 VS 2019 16.6 14
P1907R1 Inconsistencies with non-type template parameters VS 2019 16.6 20
P1971R0 US053: Mandate the return type for return_void and return_value to be void VS 2019 16.6 20
P1971R0 US065: Apply Coroutines issue 24 from P0664R8 VS 2019 16.6 20
P1979R0 Resolution to US086 VS 2019 16.6 20
P0388R4 Permit conversions to arrays of unknown bound VS 2019 16.7 20
P0466R5 Layout-compatibility and Pointer-interconvertibility Traits VS 2019 16.7 20
P0722R3 Efficient sized delete for variable sized classes VS 2019 16.7 20
P1094R2 Nested inline namespaces VS 2019 16.7 20
P1152R4 Deprecating volatile VS 2019 16.7 20
P1331R2 Permitting trivial default initialization in constexpr contexts VS 2019 16.7 20
P1358R0 2310: Type completeness and derived-to-base pointer conversions VS 2019 16.7 20
P1452R2 On the non-uniform semantics of return-type-requirements VS 2019 16.7 20
P1616R1 Using unconstrained TTPs with constrained templates VS 2019 16.7 20
P1814R0 CTAD for alias templates VS 2019 16.7 20
P1816R0 CTAD for aggregates VS 2019 16.7 20
P1957R1 Converting from T* to bool should be considered narrowing (re: US 212) VS 2019 16.7 DR
P1968R0 CWG 2282: Consistency with mismatched aligned/non-over-aligned allocation/deallocation functions VS 2019 16.7 20
P1969R0 CWG 2280: Matching a usual deallocation function with placement new VS 2019 16.7 20
P1969R0 CWG 2382: Array allocation overhead for non-allocating placement new VS 2019 16.7 20
P1969R0 CWG 2441: Inline function parameters VS 2019 16.7 20
P1971R0 US052: Non-executed return statements in coroutines VS 2019 16.7 20
P1972R0 US105: Check satisfaction of constraints for non-templates when forming pointer to function VS 2019 16.7 20
P1980R0 CA096: Declaration matching for non-dependent requires-clauses VS 2019 16.7 20
P2082R1 Fixing CTAD for aggregates VS 2019 16.7 20
P2085R0 Consistent defaulted comparisons VS 2019 16.7 20
P2103R0 US033: Allow "import" inside linkage-specifications VS 2019 16.7 20
P2107R0 US064: Copy semantics of coroutine parameters VS 2019 16.7 20
P0912R5 Coroutines VS 2019 16.8 20
P1103R3 Modules VS 2019 16.8 20
P0315R4 Allowing lambdas in unevaluated contexts VS 2019 16.8 20
P0848R3 Conditionally trivial special member functions VS 2019 16.8 20
P0960R3 Allow initializing aggregates from a parenthesized list of values VS 2019 16.8 20
P1766R1 Mitigating minor modules maladies VS 2019 16.8 20
P1811R0 Relaxing redefinition restrictions for re-exportation robustness VS 2019 16.8 20
P1874R1 Dynamic Initialization Order of Non-Local Variables in Modules VS 2019 16.8 20
P1975R0 Fixing the wording of parenthesized aggregate-initialization VS 2019 16.8 20
P0634R3 Down with typename! VS 2019 16.9 20
P0784R7 More constexpr containers VS 2019 16.9 20
P0840R2 [[no_unique_address]] attribute VS 2019 16.9 20
P1064R0 Allowing virtual function calls in constant expressions VS 2019 16.9 20
P1141R2 Yet another approach for constrained declarations VS 2019 16.9 20
P1327R1 Allowing dynamic_cast, polymorphic typeid in constant expressions VS 2019 16.9 20
P1668R1 Permitting unevaluated inline assembly in constexpr functions VS 2019 16.9 20
P1073R3 Immediate functions VS 2019 16.10 20
P1143R2 constinit VS 2019 16.10 20
P1353R0 Missing feature-test macros VS 2019 16.10 20
P0735R1 Interaction of memory_order_consume with release sequences N/D
P1236R1 Signed integers are two's complement N/D

Características de la biblioteca estándar de C++

Puede encontrar una lista más detallada de las características de la biblioteca estándar y las correcciones de errores por versión del producto en la página del registro de cambios de la wiki de STL de Microsoft en GitHub.

Característica Compatible
Características de la biblioteca estándar de C++14 Compatible
N3462 SFINAE-Friendly result_of VS 2015.2
N3302 constexpr For <complex> VS 2015
N3469 constexpr For <chrono> VS 2015
N3470 constexpr For <array> VS 2015
N3471 constexpr For <initializer_list>, <tuple>, <utility> VS 2015
N3545 integral_constant::operator()() VS 2015
N3642 UDLs For <chrono>, <string> (1729ms, "meow"s, etc.) VS 2015
N3644 Null Forward Iterators VS 2015
N3654 quoted() VS 2015
N3657 Heterogeneous Associative Lookup VS 2015
N3658 integer_sequence VS 2015
N3659 shared_mutex (Timed) VS 2015
N3668 exchange() VS 2015
N3669 Fixing constexpr Member Functions Without const VS 2015
N3670 get<T>() VS 2015
N3671 Dual-Range equal(), is_permutation(), mismatch() VS 2015
N3778 Sized Deallocation VS 2015
N3779 UDLs For <complex> (3.14i, etc.) VS 2015
N3789 constexpr For <functional> VS 2015
N3887 tuple_element_t VS 2015
N3891 Renaming shared_mutex (Timed) To shared_timed_mutex VS 2015
N3346 Minimal Container Element Requirements VS 2013
N3421 Transparent Operator Functors (less<>, etc.) VS 2013
N3655 Alias Templates For <type_traits> (decay_t, etc.) VS 2013
N3656 make_unique() VS 2013
Características de la biblioteca estándar de C++17 Compatible
LWG 2221 Formatted output operator for nullptr VS 2019 16.1
N3911 void_t VS 2015 14
N4089 Safe Conversions In unique_ptr<T[]> VS 2015 14
N4169 invoke() VS 2015 14
N4190 Removing auto_ptr, random_shuffle(), And Old <functional> Stuff VS 2015 F
N4258 noexcept Cleanups VS 2015 14
N4259 uncaught_exceptions() VS 2015 14
N4277 Trivially Copyable reference_wrapper VS 2015 14
N4279 insert_or_assign()/try_emplace() For map/unordered_map VS 2015 14
N4280 size(), empty(), data() VS 2015 14
N4366 Precisely Constraining unique_ptr Assignment VS 2015 14
N4387 Improving pair And tuple VS 2015.2 14
N4389 bool_constant VS 2015 14
N4508 shared_mutex (Untimed) VS 2015.2 14
N4510 Supporting Incomplete Types In vector/list/forward_list VS 2013 14
N4562 Library Fundamentals: <algorithm> sample() VS 2017 15.0
N4562 Library Fundamentals: <any> VS 2017 15.0
N4562 Library Fundamentals: <memory_resource>
P0337R0 Deleting polymorphic_allocator Assignment
VS 2017 15.6
N4562 Library Fundamentals: <optional> VS 2017 15.0
N4562 Library Fundamentals: <string_view> VS 2017 15.0
N4562 Library Fundamentals: <tuple> apply() VS 2017 15.0
N4562 Library Fundamentals: Boyer-Moore search()
P0253R1 Fixing Searcher Return Types
VS 2017 15.3 17
P0003R5 Removing Dynamic Exception Specifications VS 2017 15.5 17
P0004R1 Removing Deprecated Iostreams Aliases VS 2015.2 F
P0005R4 not_fn()
P0358R1 Fixes For not_fn()
VS 2017 15.5 17
P0006R0 Variable Templates For Type Traits (is_same_v, etc.) VS 2015.2 14
P0007R1 as_const() VS 2015.2 14
P0013R1 Logical Operator Type Traits (conjunction, etc.) VS 2015.2 14
P0024R2 Parallel Algorithms
P0336R1 Renaming Parallel Execution Policies
P0394R4 Parallel Algorithms Should terminate() For Exceptions
P0452R1 Unifying <numeric> Parallel Algorithms
VS 2017 15.7 G
P0025R1 clamp() VS 2015.3
P0030R1 hypot(x, y, z) VS 2017 15.7
P0031R0 constexpr For <array> (Again) And <iterator> VS 2017 15.3 17
P0032R3 Homogeneous Interface For variant/any/optional VS 2017 15.0
P0033R1 Rewording enable_shared_from_this VS 2017 15.5 14
P0040R3 Extending Memory Management Tools VS 2017 15.3 17
P0063R3 C11 Standard Library VS 2015 C11, 14
P0067R5 Elementary String Conversions VS 2019 16.4
P0074R0 owner_less<> VS 2015.2 14
P0077R2 is_callable, is_nothrow_callable VS 2017 15.0
P0083R3 Splicing Maps And Sets
P0508R0 Clarifying insert_return_type
VS 2017 15.5 17
P0084R2 Emplace Return Type VS 2017 15.3 17
P0088R3 <variant> VS 2017 15.0
P0092R1 <chrono> floor(), ceil(), round(), abs() VS 2015.2 14
P0152R1 atomic::is_always_lock_free VS 2017 15.3 17
P0154R1 hardware_destructive_interference_size, etc. VS 2017 15.3 17
P0156R0 Variadic lock_guard VS 2015.2 14
P0156R2 Renaming Variadic lock_guard to scoped_lock VS 2017 15.3 17
P0163R0 shared_ptr::weak_type VS 2017 15.0
P0174R2 Deprecating Vestigial Library Parts VS 2017 15.5 17
P0185R1 is_swappable, is_nothrow_swappable VS 2015.3
P0209R2 make_from_tuple() VS 2017 15.0
P0218R1 <filesystem>
P0219R1 Relative Paths For Filesystem
P0317R1 Directory Entry Caching For Filesystem
P0392R0 Supporting string_view In Filesystem Paths
P0430R2 Supporting Non-POSIX Filesystems
P0492R2 Resolving NB Comments for Filesystem
VS 2017 15.7 H
P0220R1 Library Fundamentals V1 VS 2017 15.6
P0226R1 Mathematical Special Functions VS 2017 15.7
P0254R2 Integrating string_view And std::string VS 2017 15.0
P0258R2 has_unique_object_representations VS 2017 15.3 I
P0272R1 Non-const basic_string::data() VS 2015.3
P0295R0 gcd(), lcm() VS 2017 15.3 17
P0298R3 std::byte VS 2017 15.3 17J
P0302R1 Removing Allocator Support In std::function VS 2017 15.5 17
P0307R2 Making Optional Greater Equal Again VS 2017 15.0
P0393R3 Making Variant Greater Equal VS 2017 15.0
P0403R1 UDLs For <string_view> ("meow"sv, etc.) VS 2017 15.3 17
P0414R2 shared_ptr<T[]>, shared_ptr<T[N]>
P0497R0 Fixing shared_ptr For Arrays
VS 2017 15.5 14
P0418R2 atomic compare_exchange memory_order Requirements VS 2017 15.3 14
P0426R1 constexpr For char_traits VS 2017 15.7
P0433R2 Integrating template deduction for class templates into the standard library
P0739R0 Improving class template argument deduction integration into the standard library
VS 2017 15.7
P0435R1 Overhauling common_type
P0548R1 Tweaking common_type and duration
VS 2017 15.3 14
P0504R0 Revisiting in_place_t/in_place_type_t<T>/in_place_index_t<I> VS 2017 15.0
P0505R0 constexpr For <chrono> (Again) VS 2017 15.3 17
P0510R0 Rejecting variants Of Nothing, Arrays, References, And Incomplete Types VS 2017 15.0
P0513R0 Poisoning hash
P0599R1 noexcept hash
VS 2017 15.3 14
P0516R0 Marking shared_future Copying As noexcept VS 2017 15.3 14
P0517R0 Constructing future_error From future_errc VS 2017 15.3 14
P0521R0 Deprecating shared_ptr::unique() VS 2017 15.5 17
P0558R1 Resolving atomic<T> Named Base Class Inconsistencies VS 2017 15.3 14
P0595R2 std::is_constant_evaluated() VS 2019 16.5 20
P0602R4 Propagating Copy/Move Triviality In variant/optional VS 2017 15.317
P0604R0 Changing is_callable/result_of To invoke_result, is_invocable, is_nothrow_invocable VS 2017 15.3 17
P0607R0 Inline Variables for the Standard Library VS 2017 15.5 17
P0618R0 Deprecating <codecvt> VS 2017 15.5 17
P0682R1 Repairing Elementary String Conversions VS 2015 15.7 17
Características de la biblioteca estándar de C++20 Compatible
P0809R0 Comparing Unordered Containers VS 2010 14
P0858R0 Constexpr Iterator Requirements VS 2017 15.3 17
P0777R1 Avoiding Unnecessary Decay VS 2017 15.7 14
P1164R1 Making create_directory() Intuitive VS 2019 16.0 20
P0550R2 remove_cvref VS 2019 16.0 20
P0318R1 unwrap_reference, unwrap_ref_decay VS 2019 16.1 20
P0457R2 starts_with()/ends_with() For basic_string/basic_string_view VS 2019 16.1 20
P0458R2 contains() For Ordered And Unordered Associative Containers VS 2019 16.1 20
P0646R1 list/forward_list remove()/remove_if()/unique() Return size_type VS 2019 16.1 20
P0769R2 shift_left(), shift_right() VS 2019 16.1 20
P0887R1 type_identity VS 2019 16.1 20
P0020R6 atomic<float>, atomic<double>, atomic<long double> VS 2019 16.2 20
P0463R1 endian VS 2019 16.2 20
P0482R6 char8_t: A type for UTF-8 characters and strings VS 2019 16.2 20
P0600R1 [[nodiscard]] For The STL, Part 1 VS 2019 16.2 20
P0653R2 to_address() VS 2019 16.2 20
P0754R2 <version> VS 2019 16.2 20
P0771R1 noexcept For std::function's Move Constructor VS 2019 16.2 20
P0487R1 Fixing operator>>(basic_istream&, CharT*) VS 2019 16.3 20
P0616R0 Using move() In <numeric> VS 2019 16.3 20
P0758R1 is_nothrow_convertible VS 2019 16.3 20
P0898R3 Standard Library Concepts VS 2019 16.3 20
P0919R3 Heterogeneous Lookup For Unordered Containers VS 2019 16.3 20
P1754R1 Rename Concepts to standard_case VS 2019 16.4 20
P0325R4 to_array from LFTS with updates VS 2019 16.5 20
P0340R3 SFINAE-Friendly underlying_type VS 2019 16.5 14
P0356R5 bind_front() VS 2019 16.5 20
P0439R0 enum class memory_order VS 2019 16.5 20
P0553R4 <bit> Rotating And Counting Functions VS 2019 16.5 20
P0556R3 <bit> ispow2(), ceil2(), floor2(), log2p1() VS 2019 16.5 20
P0595R2 is_constant_evaluated() VS 2019 16.5 20
P0631R8 <numbers> Math Constants VS 2019 16.5 20
P0655R1 visit<R>() VS 2019 16.5 20
P0738R2 istream_iterator Cleanup VS 2019 16.5 14
P0767R1 Deprecating is_pod VS 2019 16.5 20
P0966R1 string::reserve() Should Not Shrink VS 2019 16.5 20
P1209R0 erase_if(), erase() VS 2019 16.5 20
P1227R2 Signed std::ssize(), Unsigned span::size() VS 2019 16.5 20
P1355R2 Narrow Contract For ceil2() VS 2019 16.5 20
P1357R1 is_bounded_array, is_unbounded_array VS 2019 16.5 20
P1612R1 Relocating endian To <bit> VS 2019 16.5 20
P1651R0 bind_front() Should Not Unwrap reference_wrapper VS 2019 16.5 20
P1690R1 Refining Heterogeneous Lookup For Unordered Containers VS 2019 16.5 20
P1902R1 Missing Feature-Test Macros 2017-2019 VS 2019 16.5 14
P0122R7 <span>
P1024R3 Enhancing span usability
P1085R2 Removing span comparisons
P1394R4 Range constructor for span
P1872R0 span should have size_type, not index_type
VS 2019 16.6 20
P0202R3 constexpr for <algorithm> and exchange() VS 2019 16.6 20
P0357R3 Supporting Incomplete Types In reference_wrapper VS 2019 16.6 20
P0619R4 Removing C++17-Deprecated Features In C++20 VS 2019 16.6 20
P0879R0 constexpr for swapping functions VS 2019 16.6 20
P0883R2 Fixing atomic initialization VS 2019 16.6 14
P0935R0 Eradicating Unnecessarily Explicit Default Constructors VS 2019 16.6 14
P1006R1 constexpr For pointer_traits<T*>::pointer_to() VS 2019 16.6 20
P1165R1 Consistently Propagating Stateful Allocators In basic_string's operator+() VS 2019 16.6 14
P1423R3 char8_t backward compatibility remediation VS 2019 16.6 20
P1645R1 constexpr for <numeric> algorithms VS 2019 16.6 20
P0415R1 constexpr For <complex> (Again) VS 2019 16.7 20
P0476R2 <bit> bit_cast VS 2019 16.7 20
P0528R3 Atomic Compare-And-Exchange With Padding Bits VS 2019 16.7 20
P0586R2 Integer comparison functions VS 2019 16.7 20
P0674R1 make_shared() For Arrays VS 2019 16.7 20
P0718R2 atomic<shared_ptr<T>>, atomic<weak_ptr<T>> VS 2019 16.7 20
P1023R0 constexpr For std::array Comparisons VS 2019 16.7 20
P1115R3 erase()/erase_if() Return size_type VS 2019 16.7 20
P1831R1 Deprecating volatile in the standard library VS 2019 16.7 20
P1871R1 Concept traits should be named after concepts VS 2019 16.7 20
P1956R1 <bit> has_single_bit(), bit_ceil(), bit_floor(), bit_width() VS 2019 16.7 20
P1964R2 Replacing boolean With boolean-testable VS 2019 16.7 20
P1976R2 Fixed-size span construction from dynamic range VS 2019 16.7 20
P2091R0 Issues with range access CPOs VS 2019 16.7 20
P2102R0 Make "implicit expression variations" more explicit VS 2019 16.7 20
P2116R0 Remove tuple-like protocol support from fixed-extent span VS 2019 16.7 20
P0019R8 atomic_ref VS 2019 16.8 20
P0528R3 Library support for atomic compare-and-exchange with padding bits VS 2019 16.8 20
P0811R3 midpoint(), lerp() VS 2019 16.8 20
P0912R5 Library Support For Coroutines VS 2019 16.8 20
P1001R2 execution::unseq VS 2019 16.8 20
P1032R1 Miscellaneous constexpr VS 2019 16.8 20
P1065R2 constexpr INVOKE VS 2019 16.8 20
P1123R0 Editorial Guidance for merging P0019r8 and P0528r3 VS 2019 16.8 20
P1960R0 NB Comment Changes Reviewed by SG1 VS 2019 16.8 20
P0339R6 polymorphic_allocator<> VS 2019 16.9 20
P0660R10 <stop_token> and jthread VS 2019 16.9 20
P0768R1 Library Support For The Spaceship Comparison Operator <=> VS 2019 16.9 20
P1007R3 assume_aligned() VS 2019 16.9 20
P1020R1 Smart Pointer Creation With Default Initialization VS 2019 16.9 20
P1135R6 The C++20 Synchronization Library VS 2019 16.9 20
P1771R1 Library support for [[nodiscard]] for constructors VS 2019 16.9 20
P0053R7 <syncstream>
P0753R2 osyncstream Manipulators
VS 2019 16.10 20
P0355R7 <chrono> Calendars And Time Zones VS 2019 16.10 20abi
P0408R7 Efficient access To basic_stringbuf's buffer VS 2019 16.10 20
P0466R5 Library support for layout-compatibility and pointer-interconvertibility traits VS 2019 16.10 20
P0475R1 Guaranteed Copy Elision For Piecewise Construction VS 2019 16.10 20
P0591R4 Utility Functions For Uses-Allocator Construction VS 2019 16.10 20
P0608R3 Improving variant's Converting Constructor/Assignment VS 2019 16.10 20
P0645R10 <format> Text Formatting VS 2019 16.10 20abi
P0784R7 Library support for more constexpr containers VS 2019 16.10 20
P0896R4 <ranges> VS 2019 16.10 20abi
P0980R1 constexpr std::string VS 2019 16.10 20
P1004R2 constexpr std::vector VS 2019 16.10 20
P1208R6 <source_location> VS 2019 16.10 20
P1502R1 Standard Library Header Units VS 2019 16.10 20
P1614R2 Adding Spaceship <=> To The Library VS 2019 16.10 20
P1285R0 Improving Completeness Requirements For Type Traits N/D
Características de la biblioteca estándar de C++23 Compatible
P0881R7 <stacktrace> No
P0943R6 Supporting C Atomics In C++ No
P1048R1 is_scoped_enum No
P1679R3 contains() For basic_string/basic_string_view No
P1682R3 to_underlying() For Enumerations No
P2162R2 Inheriting From variant No

Un grupo de artículos enumerados juntos indica una característica estándar junto con una o varias mejoras o expansiones aprobadas. Estas características se implementan juntas.

Características de la biblioteca estándar de C

Característica Compatible
Características de la biblioteca estándar de C99 Compatible
 Macros de ortografía alternativas <iso646.h> VS 2015
 Compatibilidad con caracteres anchos <wchar.h> y <wctype.h> VS 2015
 Compatibilidad compleja en <complex.h> Parcial en VS 2015 K
 Funciones matemáticas de tipo genérico <tgmath.h> VS 2019 16.8 2104
 Características de punto flotante adicionales <float.h> VS 2015
 Especificadores float printf hexadecimales %A, %a VS 2015
 Tipos enteros extendidos <inttypes.h>, <stdint.h> VS 2015
 Familia de vscanf en <stdio.h> y <wchar.h> VS 2015
 Nuevas funciones matemáticas en <math.h> VS 2015
 Tratamiento de las condiciones de error de la biblioteca matemática (math_errhandling) VS 2015
 Acceso al entorno de punto flotante <fenv.h> VS 2015
 Especificador de conversión %lf para printf VS 2015
 Familia de funciones snprintf en <stdio.h> VS 2015
 Tipo boolean en <stdbool.h> VS 2015
 Macro va_copy VS 2015
 Especificadores de conversión strftime adicionales Parcial en VS 2015 L
Características de la biblioteca estándar de C11 Compatible
 Especificadores de alineación <stdalign.h> VS 2019 16.8 C11, 2104
aligned_alloc No M
 Sin especificadores de devolución <stdnoreturn.h> VS 2019 16.8 C11, 2104
 Compatibilidad con subprocesamiento <threads.h> No
 Compatibilidad con Atomic <stdatomic.h> No
char16_t, char32_t <uchar.h> VS 2019 16.8 C11
gets() eliminado VS 2019 16.8 C11, N
gets_s() VS 2019 16.8 C11
 Interfaces de comprobación de límites (API *_s) Parcial en VS 2015 C11, O
 Opción fopen "x" VS 2019 16.8 C11
 Aserciones estáticas VS 2019 16.8 C11, 2104
quick_exit VS 2019 16.8 C11
 Macros <complex.h> VS 2019 16.8 C11
 Características de punto flotante <float.h> VS 2019 16.8 C11

Valores admitidos

No Aún no se ha implementado.
Parcial La implementación está incompleta. Para más información, consulte la sección Notas.
VS 2010 Compatible con Visual Studio 2010.
VS 2013 Compatible con Visual Studio 2013.
VS 2015 Compatible con Visual Studio 2015 (RTW).
VS 2015.2 y VS 2015.3 indican las características que se admiten en Visual Studio 2015 Update 2 y Visual Studio 2015 Update 3, respectivamente.
VS 2017 15.0 Compatible con Visual Studio 2017, versión 15.0 (RTW).
VS 2017 15.3 Compatible con Visual Studio 2017, versión 15.3.
VS 2017 15.5 Compatible con Visual Studio 2017, versión 15.5.
VS 2017 15.7 Compatible con Visual Studio 2017, versión 15.7.
VS 2019 16.0 Compatible con Visual Studio 2019, versión 16.0 (RTW).
VS 2019 16.1 Compatible con Visual Studio 2019, versión 16.1.
VS 2019 16.2 Compatible con Visual Studio 2019, versión 16.2.
VS 2019 16.3 Compatible con Visual Studio 2019, versión 16.3.
VS 2019 16.4 Compatible con Visual Studio 2019, versión 16.4.
VS 2019 16.5 Compatible con Visual Studio 2019, versión 16.5.
VS 2019 16.6 Compatible con Visual Studio 2019, versión 16.6.
VS 2019 16.7 Compatible con Visual Studio 2019, versión 16.7.
VS 2019 16.8 Compatible con Visual Studio 2019, versión 16.8.
VS 2019 16.9 Compatible con Visual Studio 2019, versión 16.9.
VS 2019 16.10 Compatible con Visual Studio 2019, versión 16.10.\

Notas

A En el modo /std:c++14, las especificaciones de excepción dinámicas permanecen sin implementar y throw() se sigue tratando como un sinónimo de __declspec(nothrow). En C++ 17, las especificaciones de excepción dinámicas se quitaron principalmente por P0003R5, dejando un vestigio: throw() está en desuso y se debe comportar como un sinónimo de noexcept . En el modo /std:c++17, MSVC ahora se ajusta al Estándar al otorgar a throw() el mismo comportamiento que noexcept , es decir, cumplimiento mediante la terminación.

La opción del compilador /Zc:noexceptTypes solicita el comportamiento anterior de __declspec(nothrow). Es probable que throw() se elimine en una versión futura de C++. Para ayudar a migrar el código en respuesta a estos cambios en el Estándar y la implementación, se agregaron advertencias del compilador nuevas para problemas de especificación de excepciones en /std:c++17 y /permissive-.

B Se admite en el modo /permissive- Visual Studio 2017, versión 15.7. Para más información, consulte La compatibilidad con la búsqueda de nombres en dos fases llega a MSVC.

C A partir de la versión 16.6 de Visual Studio 2019, el compilador implementa completamente el preprocesador C99 a través de la opción /Zc:preprocessor. (Antes de la versión 16.6, a partir de la versión 15.8 de Visual Studio 2017, el compilador proporciona compatibilidad con el preprocesador C99 mediante la opción del compilador /experimental:preprocessor). Esta opción se activa de forma predeterminada cuando se especifica la opción /std:c11 o /std:c17 del compilador.

G Compatible con /std:c++14 con una advertencia que se puede suprimir, C4984.

E La implementación es suficiente para admitir la biblioteca del estándar C++20. Una implementación completa requiere un cambio importante del archivo binario.

F Características eliminadas cuando se especifica la opción /std:c++17 o posterior del compilador. Para volver a habilitar estas características, para facilitar la transición a los modos de lenguaje más recientes, use estas macros: _HAS_AUTO_PTR_ETC, _HAS_FUNCTION_ALLOCATOR_SUPPORT, _HAS_OLD_IOSTREAMS_MEMBERS y _HAS_UNEXPECTED.

G La biblioteca de algoritmos paralelos de ++17 está completa. Que esté completa no significa que todos los algoritmos se paralelicen en todos los casos. Los algoritmos más importantes se han paralelizado, y se proporcionan firmas de la directiva de ejecución incluso cuando no se paralelizan los algoritmos. El encabezado interno central de nuestra implementación, <yvals_core.h>, contiene la sección "Notas de algoritmos paralelos" siguiente: C++ permite a una implementación implementar algoritmos paralelos como llamadas a los algoritmos de serie. Esta implementación paraleliza varias llamadas de algoritmo comunes, pero no todas.

Se paralelizan los algoritmos siguientes:

  • adjacent_difference, adjacent_find, all_of, any_of, count, count_if, equal, exclusive_scan, find, find_end, find_first_of, find_if, find_if_not, for_each, for_each_n, inclusive_scan, is_heap, is_heap_until, is_partitioned, is_sorted, is_sorted_until, mismatch, none_of, partition, reduce, remove, remove_if, replace, replace_if, search, search_n, set_difference, set_intersection, sort, stable_sort, transform, transform_exclusive_scan, transform_inclusive_scan, transform_reduce

Estos algoritmos no están paralelizados actualmente:

  • Estos algoritmos no muestran ninguna mejora notable del rendimiento del paralelismo en el hardware de destino. Todos los algoritmos que simplemente copian o permutan elementos sin ramas suelen tener ancho de banda de memoria limitado:
    • copy, copy_n, fill, fill_n, move, reverse, reverse_copy, rotate, rotate_copy, shift_left, shift_right, swap_ranges
  • Existe confusión sobre los requisitos de paralelismo de usuario para estos algoritmos, que es probable que estén al menos en la categoría anterior:
    • generate, generate_n
  • El paralelismo efectivo de estos algoritmos puede ser inviable:
    • partial_sort, partial_sort_copy
  • Estos algoritmos aún no se han evaluado. Podemos implementar el paralelismo en una versión futura:
    • copy_if, includes, inplace_merge, lexicographical_compare, max_element, merge, min_element, minmax_element, nth_element, partition_copy, remove_copy, remove_copy_if, replace_copy, replace_copy_if, set_symmetric_difference, set_union, stable_partition, unique, unique_copy

H Esta es una implementación completamente nueva, incompatible con la versión anterior de std::experimental, necesaria por la compatibilidad con symlink, las correcciones de errores y los cambios en el comportamiento requerido estándar. Actualmente, <filesystem> proporciona tanto la versión nueva, std::filesystem, como la anterior, std::experimental::filesystem. El encabezado <experimental/filesystem> proporciona solo la implementación experimental anterior. La implementación experimental se quitará en la próxima versión sin ABI de las bibliotecas.

I Compatible con una función intrínseca de compilador.

J std::byte se habilita mediante /std:c++17 o posterior, pero como en algunos casos puede entrar en conflicto con los encabezados de Windows SDK, tiene una macro de desactivación específica. Para deshabilitarlo, defina _HAS_STD_BYTE como 0.

K MSVC no admite la palabra clave _Complex ni los tipos complejos nativos. El CRT universal <complex.h> usa macros específicas de implementación para lograr el mismo efecto. Para más información, vea Compatibilidad con cálculos matemáticos complejos de C.

L El CRT universal no implementa los modificadores de conversión alternativos strftime E y O. Estos modificadores se omiten (por ejemplo, %Oe se comporta igual que %e). Las API de configuración regional subyacentes no admiten los modificadores.

M El CTR universal no implementa C11, aligned_alloc pero proporciona _aligned_malloc y _aligned_free. Dado que el sistema operativo Windows no admite asignaciones alineadas, es poco probable que se implemente esta función.

N La declaración se quita, pero la exportación de la función permanece por compatibilidad con versiones anteriores.

O Determinadas funciones de comprobación de límites no están implementadas, tienen firmas diferentes o no forman parte del estándar C11 o C17. Estas funciones no están implementadas: abort_handler_s, ignore_handler_s, memset_s, set_constraint_handler_s, snprintf_s, snwprintf_s, strerrorlen_s y vsnwprintf_s. Estas funciones tienen firmas diferentes: gmtime_s, localtime_s, qsort_s, strtok_s, vsnprintf_s y wcstok_s. Estas funciones no aparecen en el estándar: clearerr_s y fread_s.

14 Estas características de C++17 y C++20 siempre están habilitadas, incluso cuando se especifica /std:c++14 (valor predeterminado). El motivo es que la característica se implementó antes de la introducción de las opciones /std , o porque la implementación condicional era compleja de una manera no deseable.

17 Estas características se habilitan mediante la opción del compilador /std:c++17 o posterior.

20 En las versiones anteriores a la versión 16.10 de Visual Studio 2019, estas características se habilitan mediante la opción /std:c++latest del compilador. En la versión 16.11 de Visual Studio 2019 se agregó la opción del compilador /std:c++20 para habilitar estas características.

20abi Debido al trabajo posterior al lanzamiento en curso en el estándar C++20, <format>, tanto las partes de formato de <chrono> (que se basan en <format>) como las fábricas de intervalos y los adaptadores de intervalo de <ranges> (todo lo que necesita el concepto view) solo están disponibles en /std:c++latest . Estas características estarán disponibles en /std:c++20 después de llegar al acuerdo con WG21 de que no es necesario realizar más cambios importantes en ABI. Las partes restantes de <chrono> y los algoritmos que se aplican a los intervalos se habilitan en la opción del compilador /std:c++20 desde la versión 16.11 de Visual Studio 2019.

DR Estas características están habilitadas en todos los modos de opción /std del compilador de C++. El comité de estándares de C++ adoptó este cambio como un informe de defectos retroactivo en C++11 y todas las versiones posteriores.

C11 La compatibilidad del compilador con C11 y C17 requiere la versión 16.8 o posterior de Visual Studio 2019. Excepto como se indicó, la compatibilidad con las bibliotecas de C11 y C17 requiere la compilación 10.0.20211.0 o posterior del SDK de Windows 10. Para obtener más información sobre cómo instalar la compatibilidad con C11 y C17, vea Instalación de la compatibilidad con C11 y C17 en Visual Studio.

2104 La compatibilidad de la biblioteca de C11 con esta característica requiere la compilación 10.0.20348.0 del SDK de Windows 10 (versión 2104) o posterior.

Vea también

Referencia del lenguaje C++
Biblioteca estándar de C++
Mejoras de conformidad de C++ en Visual Studio
Novedades de Visual C++ en Visual Studio
Historial de cambios de Visual C++ de 2003 a 2015
Novedades de Visual C++ de 2003 a 2015
Blog del equipo de C++