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 issue 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++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
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> 的公共成員函式) |