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<const char*>(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() { // 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) |
更新了重载的数量 其中 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> 的公共成员函数) |