当我在 Linux 2.6.26 系统(Debian 5.0.5)上设置一个短暂的超时setitimer
然后查询设置值(withgetitimer
或 another setitimer
)时,我得到一个高于我设置的值:
#include <sys/time.h>
#include <iostream>
int main() {
struct itimerval wanted, got;
wanted.it_value.tv_sec = 0;
wanted.it_value.tv_usec = 7000;
wanted.it_interval.tv_sec = 0;
wanted.it_interval.tv_usec = 0;
setitimer(ITIMER_VIRTUAL, &wanted, NULL);
getitimer(ITIMER_VIRTUAL, &got);
std::cerr << "we said: " << wanted.it_value.tv_usec << "\n"
<< "linux set: " << got.it_value.tv_usec << std::endl;
return 0;
}
返回:
we said: 7000
linux set: 12000
这是有问题的,因为我们使用一些计算后报告的剩余时间,而且它们也太大了。
这是一个已知问题吗?(谷歌搜索不起作用。)有没有人有一个好的解决方法?