我如何测量我的函数的时间,只有我的函数在使用CPU
How do I measure the time my function, and only my function is using the CPU
我在ubuntu上使用GCC,我想要一个函数来测量我的函数使用CPU的时间。我不想包括CPU在后台进程上花费的时间。
例如,如果我的函数使用CPU 10毫秒,那么处理器处理一些其他数据20毫秒,然后继续处理我的函数8毫秒。我希望它返回18ms,而不是38。我不介意如果结果是在CPU滴答。
您想要做的称为分析,Linux上的gprof
非常方便,请参阅http://www.ibm.com/developerworks/library/l-gnuprof.html。
除了Baris Demiray的回答之外,我个人可以推荐valgrind工具集中的callgrind工具(以及任何其他工具)。这在与kcachegrind/qcachegrind结合使用时特别有用,它应该可以通过ubuntu存储库获得。
gprof和callgrind这两个工具的简要描述可以在这里找到:http://kcachegrind.sourceforge.net/html/Introduction.html
您要查看clock()
(man 3 clock
)
相关文章:
- 为什么在我的函数类型后使用引用运算符 (&) 允许我修改它返回的值?
- 在哪里放置我的函数?进入我的母语 Gui 还是进入我的演示者?
- 查找定义我的 C/C++ 函数/宏的文件比'grep'更简单的方法
- 为什么我的 constexpr 对象在我的函数中不是 constexpr?
- 为什么我的函数接受"std::string"进行排序不会改变它?
- 为什么 emscripten 不编译我的函数?
- binary_search() 函数在我的函数体中不起作用
- 如何将不同大小的数组传递给我的 C++ 函数?
- 如果我想使用 cout 为我的函数提供任何输入......我该如何给出
- (C++)我的函数不返回数组
- 如何让我的重载<<运算符打印出我的函数?
- 我的函数调用 (C++) 中的未声明标识符
- 钩/绕道 d3d9 (现在/结束场景) - 似乎调用我的函数然后崩溃
- 成员函数的"this"参数具有"const"类型,但我的函数实际上不是"const"
- 我应该声明我的函数模板专业化还是定义它们就足够了
- 为什么我的函数名称中会随机出现一个额外的字母
- 为什么我的函数无法使用指针打印多维数组的元素?
- 当我从头文件和实现文件调用我的函数到我的主文件时,我没有得到任何输出
- 钩子SSDT.其他驱动程序使用我的函数
- 如何修复我的函数 popFront 为我的列表?