捕获线程的CPU时间的API

问题描述

我想测量cpu时间,而不是线程上的经过时间。例如,如果线程正在等待或睡眠,则不应将其计为cpu时间,因为该线程未处于可运行状态。因此,我获得了以下链接获取cpu时间。但是,它似乎是根据下面的测试来捕获经过的时间(我希望cpu_time_used应该接近0,但实际上是2)。我缺少什么?

https://www.gnu.org/software/libc/manual/html_node/CPU-Time.html

cat /dev/fd/19 /dev/fd/20

解决方法

请注意,clock()以核心时间为单位进行度量,即CLOCKS_PER_SEC clock()的滴答表示一个处理器上一秒钟的计算,因此它表示该进程在整个处理器上使用的时间量线程。因此,如果在睡眠期间有另一个线程在运行,它仍将增加时钟数-如果总共有两个线程,则时钟数将指示已经过去了2秒,如您所示。如果睡眠线程是唯一线程,则您将获得少量时间,例如@NateEldredge报告。在Linux上,您可以查询或设置CLOCK_THREAD_CPUTIME_ID上的计时器,就像@KamilCuk所说的那样。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...