首页 > 系统服务 > 详细

linux内核计算时间差以及jiffies溢出

时间:2014-06-01 15:00:30      阅读:1175      评论:0      收藏:0      [点我收藏+]

jiffies是每个时钟中断,都会加1,这就导致一个问题,无论jiffies(一般来说是unsigned long类型)多少个字节,总有溢出的时候。

更极端的时候,当期jiffies是0xffffffff,下一个时刻就是0x0

这样,当你计算延时/时差 的时候0x0 - 0xffffffff结果是 0xffffffff,实际上只是过了一个时钟周期,这种差别是巨大的。

那么如何防止这种情况发生呢?

很简单

假设t1是之前记录的jiffies,t2是当年的jiffies,你想要计算两者差值:

(long) t2 - (long)t1

这样就能成功避免之前的情况。

(long)0xffffffff 是0x1

(long)0x0 是0x0

所以(long)0xffffffff - (long)0x0 差值正好是1,即正确的结果。

linux内核计算时间差以及jiffies溢出,布布扣,bubuko.com

linux内核计算时间差以及jiffies溢出

原文:http://blog.csdn.net/mrpre/article/details/27890415

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!