| I/O manipulators | ||||
| Print functions(C++23) | ||||
| C-style I/O | ||||
| Buffers | ||||
(C++23) | ||||
(C++98/26*) | ||||
(C++20) | ||||
| Streams | ||||
| Abstractions | ||||
| File I/O | ||||
| String I/O | ||||
| Array I/O | ||||
(C++23) | ||||
(C++23) | ||||
(C++23) | ||||
(C++98/26*) | ||||
(C++98/26*) | ||||
(C++98/26*) | ||||
| Synchronized Output | ||||
(C++20) | ||||
| Types | ||||
| Error category interface | ||||
(C++11) | ||||
(C++11) |
| Print functions | ||||
(C++23) | ||||
println (C++23) | ||||
(C++23)(C++23) | ||||
(C++23)(C++23) |
Defined in header <print> | ||
template<class...Args> void println(std::format_string<Args...> fmt, Args&&...args); | (1) | (since C++23) |
template<class...Args> void println(std::FILE* stream, | (2) | (since C++23) |
void println(); | (3) | (since C++26) |
void println(std::FILE* stream); | (4) | (since C++26) |
Formatargs according to the format stringfmt with appended'\n' (which means that each output ends with a new-line), and print the result to a stream.
std::print(stream,"{}\n",std::format(fmt,std::forward<Args>(args)...)); | (until C++26) |
std::print(stream,std::runtime_format(std::string(fmt.get())+'\n'), | (since C++26) |
Ifstd::formatter<Ti,char> does not meet theBasicFormatter requirements for anyTi inArgs (as required bystd::make_format_args), the behavior is undefined.
Contents |
| stream | - | output file stream to write to | ||||||||||||||||||||||||||||||||||||||||||||||
| fmt | - | an object that represents the format string. The format string consists of
Each replacement field has the following format:
1) replacement field without a format specification 2) replacement field with a format specification
| ||||||||||||||||||||||||||||||||||||||||||||||
| args... | - | arguments to be formatted | ||||||||||||||||||||||||||||||||||||||||||||||
Although overloads(3,4) are added in C++26, all known implementations make them available in C++23 mode.
| Feature-test macro | Value | Std | Feature |
|---|---|---|---|
__cpp_lib_print | 202207L | (C++23) | Formatted output |
202403L | (C++26) | Unbuffered formatted output[1] | |
__cpp_lib_format | 202207L | (C++23) | Exposingstd::basic_format_string |
#include <print> int main(){// Each call to std::println ends with new-line std::println("Please");// overload (1) std::println("enter");// (1) std::print("pass");std::print("word"); std::println();// (3); valid since C++26; same effect as std::print("\n");}
Output:
Pleaseenterpassword
(C++23) | prints tostdout or a file stream usingformatted representation of the arguments (function template)[edit] |
(C++23) | outputsformatted representation of the arguments with appended'\n' (function template)[edit] |
(C++20) | stores formatted representation of the arguments in a new string (function template)[edit] |
(C++11) | prints formatted output tostdout, a file stream or a buffer (function)[edit] |