All of the source Markdown pages for the Modern C++ Tutorial on https://learnmoderncpp.com/ plus complete, working programs machine-extracted from the course text.
Note: Some Chapters have had significant changes made to update them to C++23, and not all programs compile successfully yet. In particular, use of std::println()
with import std;
does not compile. In case of issues with your compiler please see the Releases page for the C++20 version of the Tutorial.
The "headers" subdirectory contains C++ programs with legacy header #includes
, whilst the "modules" subdirectory contains the same programs using the import
keyword instead. See https://learnmoderncpp.com/2020/09/05/where-are-c-modules/ for more details about C++ compilers which have support for modules.
The "scripts" subdirectory contains a C++ program which extracts all programs from the Markdown source to the above two folders.
Most programs compile successfully under Windows with Visual Studio 2022 (v17.8 or later), some of the modules versions (as noted above) do not currently compile.
The supplied batch scripts build-vs2022-headers.bat
and build-vs2022-modules.bat
can be used to compile all of the programs within a Visual Studio command prompt, simply run:
C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvars64.bat
or similar in a command window, or create a desktop link, and then run either of the build scripts.
Alternatively, to compile individual programs from within a Visual Studio command prompt, run either (modules):
cl /EHsc /std:c++latest /MTd 00-example.cpp
or (headers):
cl /EHsc /std:c++latest 00-example.cpp
substituting the correct file for 00-example.cpp
in either case. Note that the modules versions need file std.obj
in the current directory, see the build script for how to create this.
To compile individual programs in the "headers" subdirectory under Linux, use:
g++ -std=c++23 -o 00-example 00-example.cpp
or:
clang++ -std=c++23 -o 00-example 00-example.cpp
substituting both occurrencies of 00-example
with the correct file name.
Alternatively, run one of the supplied shell scripts build-gcc-headers.sh
or build-clang-headers.sh
which are supplied in the "headers/build" subdirectory, or build-clang-modules.sh
found in the "modules/build" subdirectory.