分析 I/O C++所花费的时间
Profiling time spent in I/O C++
我有一个需要11秒的函数。我想分析一下它在 I/O 上花费了多少时间。是否有任何工具可以分析函数内花费的I/O时间?这可以给出静态数据,例如
Total Time I/O TIME Function Name
x y f
这种方法会告诉你。
只需暂停 10 次即可。每次查看堆栈。
如果你在执行 IO 的过程中发现它,比如说,其中 6 次暂停,这意味着大约 60% 的时间都在 IO 中。
如果您想知道函数 F 请求的 IO 中花费了多少,只需计算函数 F 在堆栈上时正在执行 IO 的样本数。
(GPROF 不会告诉你这一点,因为它会在 IO 期间暂停采样。
添加:或者,您可以在函数 F 中存根 IO 调用,并测量有和没有 IO 的总时间。
相关文章:
- C++为构建时间获取QDateTime的可靠方法
- 从持续时间构造std::chrono::system_clock::time_point
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- while循环中while循环的时间复杂度是多少
- 使用简单类型列表实现的指数编译时间.为什么
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 在已经使用Git的情况下减少编译时间
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何将包含epoch时间的十六进制字符串转换为time_t
- 从文本文件中读取时钟时间和事件时间并进行处理
- 具有未知值时的时间复杂性
- 如何减少花费的时间
- C++在变量给定的指定时间内关闭电脑
- rcpp函数中的清理时间很长
- C++:floor unix时间戳到UTC月份
- 如何在c++中录制具有精确帧时间戳的视频
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- KMP算法和LPS表构造的运行时间
- 为什么std::互斥需要很长的、非常不规则的时间来共享
- 使用Boost Interprocess创建托管共享内存需要很长时间