定义于头文件 <ostream>
template< class CharT, |
类模板 basic_ostream
提供字符流上的高层输出操作。受支持操作包含有格式输出(例如整数值)和无格式输出(例如生字符和字符数组)。此功能以 basic_streambuf
类所提供的接口实现,通过 basic_ios
基类访问。典型的实现中, basic_ostream
无非继承的数据成员。
非成员函数
插入字符数据
operator<<(std::basic_ostream)
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 ); | |||
template< class CharT, class Traits > basic_ostream<CharT,Traits>& operator<<( basic_ostream<CharT,Traits>& os, const CharT* s ); | (2) | ||
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 ); | |||
template< class CharT, class Traits, class T > basic_ostream< CharT, Traits >& operator<<( basic_ostream<CharT,Traits>&& os, const T& value ); | (3) | (C++11 起) |
插入字符或字符串。
1) 表现如有格式输出函数 (FormattedOutputFunction) 。在构造并检查 sentry 对象后,插入字符 ch
。若字符类型不是 CharT
,则它首先以 os.widen(ch) 转换。按下列方式确定填充:若 os.width()>1
,则添加 os.width()-1
个 os.fill()
的副本到输出字符,以组成输出字符序列。 若 (out.flags()&std::ios_base::adjustfield) == std::ios_base::left ,则填充字符被置于输出字符之后,否则在之前。插入前,调用 os.width(0) 以取消 std::setw 的效果,若它存在。
2) 表现如有格式输出函数 (FormattedOutputFunction) 。在构造并检查 sentry 对象后,插入来自首元素为 s
所指向的字符数组的相继字符。
- 对于第一和第三重载(其中
CharT
匹配ch
的类型),准确插入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 ,则添加填充字符到输出序列的末尾,否则添加它们到序列之前。 在插入后,调用 width(0) 取消 std::setw 的效果,若它存在。
若 s
为空指针则行为未定义。
3) 给定到输出流对象的右值引用,调用适当的插入运算符(等价于 os << value )。此函数不参与重载决议,除非表达式 os << value 为良式。 (C++17 起)
参数
os | - | 要插入数据的输出流 |
ch | - | 要插入的字符 |
s | - | 指向要插入的字符串的指针 |
返回值
os
注意
LLVM libc++ 中的重载 (3) 实现 LWG#1203 并返回与参数相同的类型,故如 (std::ostringstream() << 1.2).str() 的代码可以编译。
调用示例
#include <iostream>
#include <fstream>
int main()
{
std::cout << "Hello, world" // const char* 重载
<< std::endl; // char 重载
std::ofstream("test.txt") << 1.2; // 右值重载
}
输出