问题描述
我想测量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所说的那样。