operator<<(std::basic_ostream)
在标头 <ostream> 定义 | ||
basic_ostream 与字符 | ||
(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 与字符数组 | ||
(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 右值 | ||
template<class Ostream, class T > Ostream&& operator<<( Ostream&& os, const T& value ); | (3) | (C++11 起) |
basic_ostream 与 UTF 字符/数组的被删除重载 | ||
(4) | (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>& | ||
插入字符或字符串。
- 如果 os.width()>1,那么向输出字符添加 os.width()-1 个 os.fill() 的副本,以组成输出字符序列。
- 如果 (out.flags()&std::ios_base::adjustfield)==std::ios_base::left,那么填充字符被置于输出字符之后,否则在其之前。
- 对于第一和第三重载(其中
CharT
匹配 ch 的类型),恰好插入 traits::length(s) 个字符。 - 对于第二重载,恰好插入 std::char_traits<char>::length(s) 个字符。
- 对于最后两个重载,恰好插入 traits::length(reinterpret_cast<constchar*>(s)) 个字符。
- 如果要插入的字符数少于 os.width(),那么向字符序列添加足够数量的 os.fill() 副本,使得它的长度等于 os.width()。
- 如果 (out.flags()&std::ios_base::adjustfield)==std::ios_base::left,那么向输出序列的末尾添加填充字符,否则将它们添加到序列之前。
Ostream
是公开且无歧义地派生自 std::ios_base 的类类型时才会参与重载决议。目录 |
[编辑]参数
os | - | 要插入数据的输出流 |
ch | - | 要插入的字符 |
s | - | 指向要插入的字符串的指针 |
[编辑]返回值
[编辑]注解
在解决 LWG 问题 1203 前,如 (std::ostringstream()<<1.2).str() 的代码无法编译。
[编辑]示例
#include <fstream>#include <iostream> void foo(){// 错误:operator<< (basic_ostream<char, _Traits>&, char8_t) 被弃置// 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"// 使用 const char* 重载<<'\n';// 使用 char 重载std::ofstream("test.txt")<<1.2;// 使用右值重载 std::cout<< u8'!'<<'\n';// 使用程序定义的 operator<<(os, char8_t const&)}
输出:
Hello, world !
[编辑]缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 167 | C++98 | (2) 中的所有重载插入的字符数 都是 traits::length(s) | 更新 CharT 与 ch 的类型不匹配的重载插入的字符数 |
LWG 1203 | C++11 | 右值流的重载返回到基类的左值引用 | 返回到派生类的右值引用 |
LWG 2011 | C++98 | 填充由 std::num_put::do_put() 确定 | 由运算符自身确定 |
LWG 2534 | C++11 | 右值流的重载未被制约 | 已制约 |
[编辑]参阅
插入带格式数据 (公开成员函数) | |
(C++23) | 输出各实参的格式化表示 (函数模板) |
拓宽字符 ( std::basic_ios<CharT,Traits> 的公开成员函数) |