Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Microsoft C++ (MSVC) Build Tools makes conformance improvements and bug fixes in every release. Starting with Visual Studio 2026 version 18.0, major improvements are organized by MSVC Build Tools version number. To jump directly to the changes for a specific version, use the In this article links at the top of this article.
For changes in earlier versions of Visual Studio:
| Version | Conformance improvements link |
|---|---|
| 2022 | C++ conformance improvements in Visual Studio 2022 |
| 2019 | C++ conformance improvements in Visual Studio 2019 |
| 2017 | C++ conformance improvements in Visual Studio 2017 |
| 2003-2015 | Visual C++ What's New 2003 through 2015 |
C++ conformance improvements, behavior changes, and bug fixes in MSVC Build Tools v14.50
MSVC Build Tools v14.50 introduces improvements to the MSVC compiler and standard library, including better C++23 standards conformance, enhanced reliability, and improved correctness. This release also includes numerous bug fixes and updates that benefit large-scale C++ development.
This version shipped first with Visual Studio 2026 version 18.0 and includes version 19.50 of the MSVC compiler.
Key highlights of this release include:
- Advanced C++23 feature support including
auto(x)decay-copy and#warningdirective. - Comprehensive
constexprimprovements, particularly for virtual functions. - Major stability improvements for C++ modules.
- Extensive reliability fixes reducing internal compiler errors.
- Enhanced C++/CLI support for managed code scenarios.
- The Microsoft C++ standard library (MSVC STL) no longer supports targeting Windows 7/Server 2008 R2, Windows 8/Server 2012, or Windows 8.1/Server 2012 R2.
- Windows 10/Server 2016 are the minimum supported operating systems.
For more information about performance improvements, bug fixes, and conformance updates in the standard library, see STL Changelog, which is updated regularly.
C++23 Features
MSVC Build Tools v14.50 adds support for several C++23 features, bringing the compiler closer to full C++23 conformance.
P0849R8: auto(x) - decay-copy in the language
P0849R8 introduces the auto(x) syntax for decay-copy operations directly in the language, providing a more concise way to express decay-copy semantics.
Before P0849R8, you needed to explicitly perform decay operations:
// Before P0849R8:
void pop_front_alike(auto& x)
{
using T = std::decay_t<decltype(x.front())>;
std::erase(x, T(x.front()));
}
After P0849R8, you can use the simpler auto(x) syntax:
// After P0849R8:
void pop_front_alike(auto& x)
{
std::erase(x, auto(x.front()));
}
This feature provides a standardized way to perform decay-copy operations, making code more readable and reducing the need for verbose template metaprogramming.
P2437R1: C++23 #warning directive
P2437R1 implements the C++23 #warning preprocessor directive, providing a standard way to emit warnings during compilation.
// Valid before C++23.
#error bad configuration...
// Valid after C++23.
#warning configuration deprecated...
The #warning directive allows you to emit diagnostic messages without stopping compilation, making it useful for deprecation notices and configuration warnings. For more information, see #warning directive (C/C++).
CWG Issue 2586: Explicit object parameter for assignment and comparison
CWG Issue 2586 allows explicit object parameters in assignment and comparison operators, enabling more flexible operator definitions.
struct S
{
S& operator=(this S&, const S&) = default; // Valid after CWG2586.
auto operator<=>(this const S&, const S&) = default; // Valid after CWG2586.
};
This change allows you to use the explicit object parameter syntax (deducing this) in assignment and comparison operators, providing more consistent syntax across different types of member functions.
P2266R1 : Simpler implicit move
The introduction of P2266R1 may cause code that was previously treated as an lvalue to be treated as an xvalue or a prvalue. For example:
#include <utility>
template<typename T>
T& f(T&& t)
{
return t;
}
struct S { };
void g()
{
S s1{ };
S& s2 = f(std::move(s1));
}
In C++20, and earlier, this code compiled because even though the type of t is S&& the use of t in return t is treated as a glvalue and so it can bind to the return type.
With C++23, t is treated as an xvalue and so it can't bind to an lvalue reference.
One fix is to change to the return type of the function from T& to T&& but this may affect code that calls this function. An alternative is to use the feature test macro that is associated with this change. For example:
#include <type_traits>
template<typename T>
T& f(T&& t)
{
#if defined(__cpp_implicit_move)
return static_cast<std::remove_reference_t<T>&>(t);
#else
return t;
#endif
}
Adding the cast means that the value-category of the return expression is now an lvalue and so it can bind to the return type.
P2280R4: References to unknown values during constant evaluation
P2280R4 allows references to unknown values during constant evaluation, relaxing restrictions on constexpr evaluation.
template <typename T, size_t N>
constexpr size_t array_size(T (&)[N])
{
return N;
}
void check(int const (¶m)[3])
{
constexpr auto s2 = array_size(param); // Previously ill-formed, now accepted as a constant expression after P2280R4.
}
This improvement allows more code to be evaluated at compile time, particularly when dealing with function parameters in template contexts.
Conformance enhancements
Improved adherence to C++ standards includes better handling of attributes, templates, and C++20/C++23 features.
Attribute support
- Added support for
[[maybe_unused]]on labels. - Fixed warning C4102 (unreferenced label) when the only reference was from a discarded
if constexprbranch.
Template and specialization fixes
- Diagnosed ill-formed friend explicit specializations that were incorrectly accepted in C++20 or later.
- Added
/Zc:enumEncodingswitch to correctly encode enum nontype template parameters. - Fixed issues with missing 'template' keyword diagnostics
C++20 and C++23 Features
- Enhanced multidimensional
operator[]support - Improved concept and constraint evaluation
Smaller conformance updates
MSVC Build Tools v14.50 includes numerous smaller conformance improvements that enhance C++ standard compliance:
- CWG2635: Constrained structured bindings support
- CWG2465: Coroutine parameters passed to promise constructor improvements
- CWG2496: Ref-qualifiers and virtual overriding corrections
- CWG2506: Structured bindings and array cv-qualifiers fixes
- CWG2507: Default arguments for
operator[]support - CWG2585: Behavior alignment with standard requirements
- CWG2521: Deprecation of 'operator string-literal identifier'
- CWG2528: Relaxed conversion rules for the spaceship operator
- P2360R0: Extended init-statement definition to allow alias-declarations
- P2290R3: C++23 hexadecimal/octal delimited escape sequence support in string literals
- P2797R0: Resolution for CWG2692 regarding static and explicit object member functions with the same parameter-type-lists
- P2266R3: Simpler implicit move semantics
Bug fixes
Bug fixes for C++ Modules, constexpr, and other fixes were made in MSVC Build Tools v14.50.
For a detailed list of bug fixes, see Compiler Improvements in v14.50.
Encoding of certain nontype template arguments corrected
Affects /std:c++20 or later.
Certain nontype pointer type template arguments involving subobjects could lead to linking issues or in some cases silent bad code generation where what should be distinct specializations collide.
struct A
{
int x;
};
struct B
{
int y;
};
template <auto p> void f();
int main()
{
static A a;
static B b;
constexpr auto px = &a.x;
constexpr auto py = &b.y;
f<px>(); // incorrect encoding of argument 'px'
f<py>(); // incorrect encoding of argument 'py', collided with 'px'.
}
With this fix, the two calls to f get distinct encodings, as required.
Migrating to MSVC Build Tools v14.50
When upgrading to MSVC Build Tools v14.50, consider the following potential breaking changes and migration guidance:
C++23 feature adoption
- Update code to take advantage of new
auto(x)decay-copy syntax for cleaner template code - Consider using
#warningdirectives for deprecation notices instead of error-prone conditional compilation - Review explicit object parameter usage in operators for improved consistency
constexpr improvements
- Existing
constexprcode may now compile that previously failed, particularly with virtual functions - Review constant evaluation code for potential new optimization opportunities
- Update CRTP patterns that may now work correctly with static constexpr members
Modules migration
- Projects using C++20 modules should see improved stability and compatibility
- Header units now work more reliably with large codebases like Unreal Engine 5
- Consider migrating from traditional headers to modules for better compilation performance
Compiler diagnostics
- New warnings may appear for previously undiagnosed issues
- Review enum type usage if using
/Zc:enumTypes - Update code that relies on implicit conversions that may now be flagged
C code updates
- C23 features are available with
/std:clatest typeofbehavior changes may affect existing code- Review preprocessor usage for new
__VA_OPT__availability
Provide feedback
For the latest updates and to provide feedback, visit the Visual Studio Developer Community or contact the team at visualcpp@microsoft.com. Follow us on X @visualc or BlueSky @msftcpp.bsky.social.
If you encounter problems with MSVC in Visual Studio 2026, please let us know via the Report a Problem option, either from the installer or the Visual Studio IDE itself.
See also
Microsoft C/C++ language conformance
What's new for C++ in Visual Studio
C++ conformance improvements in Visual Studio 2022