Chinaunix首页 | 论坛 | 博客
  • 博客访问: 15496242
  • 博文数量: 2005
  • 博客积分: 11986
  • 博客等级: 上将
  • 技术积分: 22535
  • 用 户 组: 普通用户
  • 注册时间: 2007-05-17 13:56
文章分类

全部博文(2005)

文章存档

2014年(2)

2013年(2)

2012年(16)

2011年(66)

2010年(368)

2009年(743)

2008年(491)

2007年(317)

分类: LINUX

2008-03-25 15:49:26

#include <sys/time.h>
#include <time.h>
#include <stdio.h>

int main(int argc, char *argv[])
{
    struct timeval time_ticks;
    unsigned int pre_value,prev_s_value;;
    unsigned int cur_value;
    unsigned int interval_tick;
    gettimeofday(&time_ticks,NULL);
    pre_value = cur_value = time_ticks.tv_usec;
    prev_s_value = time_ticks.tv_sec;
    for(;;)
    {
        gettimeofday(&time_ticks,NULL);
        cur_value = time_ticks.tv_usec;
        //if(cur_value != pre_value)
        {
            /*
            if(cur_value > pre_value)
            {
                interval_tick = cur_value - pre_value;
            }else interval_tick = pre_value - cur_value;//从0xfffffxxx时刻开始进入的程序
            */

            interval_tick = cur_value - pre_value;
            if(interval_tick >= 1000)
            {
                pre_value = cur_value;
                fprintf(stderr,"C");
            }
        }
        cur_value = time_ticks.tv_sec;
        if(cur_value - prev_s_value)
        {
            prev_s_value = cur_value;
            fprintf(stderr,"S");
        }
    }
}

阅读(1562) | 评论(2) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2008-04-01 09:11:12

唉,直接 usleep(100*1000)就解决了

chinaunix网友2008-03-27 10:56:09

tv_usec的最大值为1000000,在kernel内部,如果tv_usec>1s即: tv_usec>1000000,会转换为tv_sec秒值,所以tv_usec永远都小于1000000