C++基础之std-先stringstream后cout

通常我们会看到在cout之前会采用stringstream,而不是直接输出。

    std::stringstream ss_1;
    ss_1 << "this is ";
    ss_1 << "test.\n";
    std::cout << ss_1.str() << std::endl;

如下实验后发现,其实直接cout的时间使用更少,但system的io也会比较大,但为什么要先使用stringstream呢?

原因是我们当时不需要直接输出到console上,而是想先存在,之后发送到文件,或发送到数据库等,其他输出,这样采用先stringstream后cout的方式,更能兼容算法的统一性。

#include <iostream>
#include <chrono>
#include <thread>
#include <sstream>
#include <iomanip>

int main(void)
{
    std::cout << "Fill:\n"
        << std::left << std::setfill(' ') << std::setw(12) << -1.23 << std::right << std::setfill(' ') << std::setw(12) << std::hex << std::showbase << 42 << '\n'
        << std::left << std::setfill(' ') << std::setw(12) << -1.3 << std::right << std::setfill(' ') << std::setw(12) << std::hex << std::showbase << 142 << '\n'
        << std::left << std::setfill(' ') << std::setw(12) << -1 << std::right << std::setfill(' ') << std::setw(12) << std::hex << std::showbase << 4142 << '\n';

    auto start = std::chrono::high_resolution_clock::now();
    std::chrono::duration<double> sum_diff_1 = start - start;
    std::chrono::duration<double> sum_diff_2 = start - start;
    std::chrono::duration<double> sum_diff_3 = start - start;

    unsigned int idx = 1000;
    while (idx--)
    {
        auto start_1 = std::chrono::high_resolution_clock::now();
        std::stringstream ss_1;
        for (unsigned int i = 0; i < 5; ++i) {
            ss_1 << "this is test.\n";
        }
        std::cout << ss_1.str() << std::endl;
        auto end_1 = std::chrono::high_resolution_clock::now();

        auto start_2 = std::chrono::high_resolution_clock::now();
        std::stringstream ss_2;
        for (unsigned int i = 0; i < 5; ++i) {
            ss_2 << "this is test." << std::endl;
        }
        std::cout << ss_2.str() << std::endl;
        auto end_2 = std::chrono::high_resolution_clock::now();

        auto start_3 = std::chrono::high_resolution_clock::now();
        for (unsigned int i = 0; i < 5; ++i) {
            std::cout << "this is test." << std::endl;
        }
        auto end_3 = std::chrono::high_resolution_clock::now();

        std::chrono::duration<double> diff_1 = end_1 - start_1;
        std::chrono::duration<double> diff_2 = end_2 - start_2;
        std::chrono::duration<double> diff_3 = end_3 - start_3;

        sum_diff_1 += diff_1;
        sum_diff_2 += diff_2;
        sum_diff_3 += diff_3;
    }

    std::cout << "ss \\n    " << sum_diff_1.count() << std::endl;
    std::cout << "ss endl  " << sum_diff_2.count() << std::endl;
    std::cout << "cout     " << sum_diff_3.count() << std::endl;

    getchar();
    return 0;
}
/*
ss \n    14.6097
ss endl  14.508
cout     13.9853
*/

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值