std::flush

来自cppreference.com
< cpp‎ | io‎ | manip

 
 
 
输入/输出操纵符
浮点格式
原文:
Floating-point formatting
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
整型格式
原文:
Integer formatting
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
布尔格式
原文:
Boolean formatting
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
场的宽度和填充控制
原文:
Field width and fill control
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
其他格式
原文:
Other formatting
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
空白处理
原文:
Whitespace processing
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
输出冲洗
原文:
Output flushing
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
flush
状态标志位操作
原文:
Status flags manipulation
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
时间和金钱I / O
原文:
Time and money I/O
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
(C++11)
(C++11)
(C++11)
(C++11)
 
定义于头文件 <ostream>
template< class CharT, class Traits >
std::basic_ostream<charT,traits>& flush( std::basic_ostream<CharT, Traits>& os );
刷新的输出序列os为通过调用os.flush().
原文:
Flushes the output sequence os as if by calling os.flush().
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
这是一个只输出的I / O机械手,它可被称为用一个表达式如out << std::flush任何out类型std::basic_ostream
原文:
This is an output-only I/O manipulator, it may be called with an expression such as out << std::flush for any out of type std::basic_ostream.
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

目录

[编辑] 注释

产生立即输出一个不完整的行,例如,可以使用该机械手显示输出时,从一个长期运行的进程,多线程的活动记录或记录活动的程序,可能会意外崩溃。 std::cout还需要一个明确的冲洗调用std::system之前,如果产生的进程进行任何屏幕I / O(一个常见的​​例子是在Windowsstd::system("pause"))。在大多数其他常见的互动式I / O的情况std::endl是多余的,因为std::cout任何输入,输出到std::cin或程序终止,强制调用std::cerr使用时std::cout.flush().
原文:
This manipulator may be used to produce an incomplete line of output immediately, e.g. when displaying output from a long-running process, logging activity of multiple threads or logging activity of a program that may crash unexpectedly. An explicit flush of std::cout is also necessary before a call to std::system, if the spawned process performs any screen I/O (a common example is std::system("pause") on Windows). In most other usual interactive I/O scenarios, std::endl is redundant when used with std::cout because any input from std::cin, output to std::cerr, or program termination forces a call to std::cout.flush().
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
当一个完整的输出需要被刷新,std::endl机械手可能会被使用
原文:
When a complete line of output needs to be flushed, the std::endl manipulator may be used.
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
当每个输出操作都需要被刷新,std::unitbuf机械手可能会被使用
原文:
When every output operation needs to be flushed, the std::unitbuf manipulator may be used.
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

[编辑] 参数

os -
引用到输出流
原文:
reference to output stream
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

[编辑] 返回值

os(参考操作后到流)
原文:
os (reference to the stream after manipulation)
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

[编辑] 示例

不使用的std ::冲洗,输出是相同的,但可能不会出现在实时.
原文:
Without std::flush, the output would be the same, but may not appear in real time.
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

#include <iostream>
#include <chrono>
template<typename Diff>
void log_progress(Diff d)
{
    std::cout << "..("
              << std::chrono::duration_cast<std::chrono::milliseconds>(d).count()
              << " ms).." << std::flush;
}
int main()
{
    volatile int sink=0;
 
    auto t1 = std::chrono::high_resolution_clock::now();
    for(int j=0; j<5; ++j)
    {
        for(int n=0; n<10000; ++n)
            for(int m=0; m<20000; ++m)
                sink += m*n; // do some work
        auto now = std::chrono::high_resolution_clock::now();
        log_progress(now - t1);
    }
    std::cout << '\n';
}

输出:

..(450 ms)....(901 ms)....(1350 ms)....(1800 ms)....(2250 ms)..

[编辑] 另请参阅

控制是否每次输出后刷新
原文:
controls whether output is flushed after each operation
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

(函数) [编辑]
输出'\n'并刷新输出流
原文:
outputs '\n' and flushes the output stream
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

(函数模板) [编辑]
与底层存储设备同步
原文:
synchronizes with the underlying storage device
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

(std::basic_ostream 的公开成员函数) [编辑]