繁体   English   中英

对std :: cout对程序性能的影响

[英]Affect on std::cout on performance of the program

我编写了一个程序,该程序将获取文件详细信息并将其放置在SQLite数据库中。 在此过程中,我观察了两种情况:

方案1:

  1. 遍历每个文件,并将文件详细信息(路径)填充到数据库(sqlite3)中。
  2. 对于遇到的每个文件,请保留一个计数器并通过std :: cout打印该计数器。 执行此程序所需时间:30分钟

方案2:

  1. 遍历每个文件,并将文件详细信息(路径)填充到数据库(sqlite3)中。

执行此程序所需时间:7分钟

我还不清楚为什么只是因为std::cout ,所花费的时间是不打印的时间的5倍

非常感谢您对此方案提出任何建议,非常感谢。

问候,拉维

尝试使用std::ios_base::sync_with_stdio(false) ,默认情况下std :: cout与stdio同步

打印到控制台成本很高。 通常比写入文件更耗时。

我敢打赌,您的代码可以在不到一分钟的时间内运行。 确保在事务包含一些插入内容。 您也可以在一个语句中使用多个插入内容,例如对此问题的答案中所述。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM