operator<<(std::basic_ostream)
|   Defined in header  <ostream>
  | 
||
|   basic_ostream and character  | 
||
| (1) | ||
|   template< class CharT, class Traits > basic_ostream<CharT, Traits>&  | 
||
|   template< class CharT, class Traits > basic_ostream<CharT, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   basic_ostream and character array  | 
||
| (2) | ||
|   template< class CharT, class Traits > basic_ostream<CharT, Traits>&  | 
||
|   template< class CharT, class Traits > basic_ostream<CharT, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   basic_ostream rvalue  | 
||
|   template< class Ostream, class T > Ostream&& operator<<( Ostream&& os, const T& value );  | 
(3) | (since C++11) | 
|   deleted overloads for basic_ostream and UTF character/array  | 
||
| (4) | (since C++20) | |
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<wchar_t, Traits>&  | 
||
|   template< class Traits > basic_ostream<wchar_t, Traits>&  | 
||
|   template< class Traits > basic_ostream<wchar_t, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<char, Traits>&  | 
||
|   template< class Traits > basic_ostream<wchar_t, Traits>&  | 
||
|   template< class Traits > basic_ostream<wchar_t, Traits>&  | 
||
|   template< class Traits > basic_ostream<wchar_t, Traits>&  | 
||
Inserts a character or a character string.
- If os.width() > 1, then os.width() - 1 copies of os.fill() are added to the output character to form the output character sequence.
 - If (out.flags() & std::ios_base::adjustfield) == std::ios_base::left, the fill characters are placed after the output character, otherwise before.
 
-  For the first and third overloads (where 
CharTmatches the type of ch), exactly traits::length(s) characters are inserted. - For the second overload, exactly std::char_traits<char>::length(s) characters are inserted.
 - For the last two overloads, exactly traits::length(reinterpret_cast<const char*>(s)) are inserted.
 
- If the number of characters to insert is less than os.width(), then enough copies of os.fill() are added to the character sequence to make its length equal os.width().
 - If (out.flags() & std::ios_base::adjustfield) == std::ios_base::left, the fill characters are added at the end of the output sequence, otherwise they are added before the output sequence.
 
Ostream is a class type publicly and unambiguously derived from std::ios_base.Parameters
| os | - | output stream to insert data to | 
| ch | - | reference to a character to insert | 
| s | - | pointer to a character string to insert | 
Return value
Notes
Before LWG issue 1203, code such as (std::ostringstream() << 1.2).str() does not compile.
Example
#include <fstream> #include <iostream> void foo() { // error: operator<< (basic_ostream<char, _Traits>&, char8_t) is deleted // std::cout << u8'z' << '\n'; } std::ostream& operator<<(std::ostream& os, char8_t const& ch) { return os << static_cast<char>(ch); } int main() { std::cout << "Hello, world" // uses `const char*` overload << '\n'; // uses `char` overload std::ofstream{"test.txt"} << 1.2; // uses rvalue overload std::cout << u8'!' << '\n'; // uses program-defined operator<<(os, char8_t const&) }
Output:
Hello, world !
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior | 
|---|---|---|---|
| LWG 167 | C++98 | the number of characters inserted for all overloads in (2) was traits::length(s)  | 
updated the numbers for the overloads where CharT does not match the type of ch
 | 
| LWG 1203 | C++11 | overload for rvalue stream returned lvalue reference to the base class  | 
returns rvalue reference to the derived class  | 
| LWG 2011 | C++98 | padding was determined by std::num_put::do_put() | determined by the operator itself | 
| LWG 2534 | C++11 | overload for rvalue stream was not constrained | constrained | 
See also
|   inserts formatted data  (public member function)  | |
|    (C++23)  | 
  outputs formatted representation of the arguments  (function template)  | 
|   widens characters  (public member function of std::basic_ios<CharT,Traits>)  |