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
CharT
matches 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<constchar*>(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.Contents |
[edit]Parameters
os | - | output stream to insert data to |
ch | - | reference to a character to insert |
s | - | pointer to a character string to insert |
[edit]Return value
[edit]Notes
Before LWG issue 1203, code such as (std::ostringstream()<<1.2).str() does not compile.
[edit]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` overloadstd::ofstream{"test.txt"}<<1.2;// uses rvalue overload std::cout<< u8'!'<<'\n';// uses program-defined operator<<(os, char8_t const&)}
Output:
Hello, world !
[edit]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 |
[edit]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> ) |