命名空间
变体
操作

operator<<(std::basic_ostream)

来自 cppreference.cn
< cpp‎ | io‎ | basic ostream
 
 
 
 
定义于头文件 <ostream>
basic_ostream 和字符
(1)
template< class CharT, class Traits >

basic_ostream<CharT, Traits>&

    operator<<( basic_ostream<CharT, Traits>& os, CharT ch );
template< class CharT, class Traits >

basic_ostream<CharT, Traits>&

    operator<<( basic_ostream<CharT, Traits>& os, char ch );
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, char ch );
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, signed char ch );
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, unsigned char ch );
basic_ostream 和字符数组
(2)
template< class CharT, class Traits >

basic_ostream<CharT, Traits>&

    operator<<( basic_ostream<CharT, Traits>& os, const CharT* s );
template< class CharT, class Traits >

basic_ostream<CharT, Traits>&

    operator<<( basic_ostream<CharT, Traits>& os, const char* s );
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, const char* s );
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, const signed char* s );
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, const unsigned char* s );
basic_ostream 右值
template< class Ostream, class T >
Ostream&& operator<<( Ostream&& os, const T& value );
(3) (since C++11)
为 basic_ostream 和 UTF 字符/数组 删除的重载
(4) (since C++20)
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, wchar_t ch ) = delete;
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, char8_t ch ) = delete;
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, char16_t ch ) = delete;
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, char32_t ch ) = delete;
template< class Traits >

basic_ostream<wchar_t, Traits>&

    operator<<( basic_ostream<wchar_t, Traits>& os, char8_t ch ) = delete;
template< class Traits >

basic_ostream<wchar_t, Traits>&

    operator<<( basic_ostream<wchar_t, Traits>& os, char16_t ch ) = delete;
template< class Traits >

basic_ostream<wchar_t, Traits>&

    operator<<( basic_ostream<wchar_t, Traits>& os, char32_t ch ) = delete;
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, const wchar_t* s ) = delete;
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, const char8_t* s ) = delete;
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, const char16_t* s ) = delete;
template< class Traits >

basic_ostream<char, Traits>&

    operator<<( basic_ostream<char, Traits>& os, const char32_t* s ) = delete;
template< class Traits >

basic_ostream<wchar_t, Traits>&

    operator<<( basic_ostream<wchar_t, Traits>& os, const char8_t* s ) = delete;
template< class Traits >

basic_ostream<wchar_t, Traits>&

    operator<<( basic_ostream<wchar_t, Traits>& os, const char16_t* s ) = delete;
template< class Traits >

basic_ostream<wchar_t, Traits>&

    operator<<( basic_ostream<wchar_t, Traits>& os, const char32_t* s ) = delete;

插入一个字符或一个字符串。

1) 行为如同 FormattedOutputFunction。在构造并检查 sentry 对象之后,插入字符 ch。如果 ch 的类型为 charos字符容器类型不是 char,则将插入 os.widen(ch) 代替。
填充确定如下
  • 如果 os.width() > 1,则将 os.width() - 1os.fill() 的副本添加到输出字符,以形成输出字符序列。
  • 如果 (out.flags() & std::ios_base::adjustfield) == std::ios_base::left,则填充字符放在输出字符之后,否则放在之前。
插入后,调用 os.width(0) 以取消 std::setw 的效果(如果有)。
2) 行为如同 FormattedOutputFunction。在构造并检查 sentry 对象之后,从字符数组中插入连续的字符,该字符数组的第一个元素由 s 指向。
  • 对于第一个和第三个重载(其中 CharTch 的类型匹配),恰好插入 traits::length(s) 个字符。
  • 对于第二个重载,恰好插入 std::char_traits<char>::length(s) 个字符。
  • 对于最后两个重载,恰好插入 traits::length(reinterpret_cast<const char*>(s)) 个字符。
在插入之前,首先,所有字符都使用 os.widen() 加宽,然后填充确定如下
  • 如果要插入的字符数少于 os.width(),则将足够多的 os.fill() 副本添加到字符序列,使其长度等于 os.width()
  • 如果 (out.flags() & std::ios_base::adjustfield) == std::ios_base::left,则填充字符添加到输出序列的末尾,否则添加到输出序列之前。
插入后,调用 os.width(0) 以取消 std::setw 的效果(如果有)。
如果 s 是空指针,则行为未定义。
3) 调用适当的插入运算符,给定输出流对象的右值引用(等效于 os << value)。仅当表达式 os << value 格式良好且 Ostream 是公开且明确地从 std::ios_base 派生的类类型时,此重载才参与重载解析。
4) 接受 char16_tchar32_t 等(或其空终止序列)的重载被删除:不允许使用 std::cout << u'X'。以前,这些会打印整数或指针值。

内容

[编辑] 参数

os - 要向其插入数据的输出流
ch - 要插入的字符的引用
s - 指向要插入的字符串的指针

[编辑] 返回值

1,2) os
3) std::move(os)

[编辑] 注解

LWG 问题 1203 之前,诸如 (std::ostringstream() << 1.2).str() 之类的代码无法编译。

[编辑] 示例

#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&)
}

输出

Hello, world
!

[编辑] 缺陷报告

以下行为变更缺陷报告已追溯应用于先前发布的 C++ 标准。

DR 应用于 已发布行为 正确行为
LWG 167 C++98 为所有插入的字符数
(2) 中的重载是 traits::length(s)
更新了重载的数字
其中 CharTch 的类型不匹配
LWG 1203 C++11 右值流的重载返回
基类的左值引用
返回右值引用
到派生类
LWG 2011 C++98 填充由 std::num_put::do_put() 确定 由运算符本身确定
LWG 2534 C++11 右值流的重载未受约束 受约束

[编辑] 参见

插入格式化数据
(public member function) [编辑]
输出参数的格式化表示
(function template) [编辑]
加宽字符
(public member function of std::basic_ios<CharT,Traits>) [编辑]