1、gettimeofday()

获取的时间为从1970-1-1 00:00:00到目前为止的时间。

当使用该函数获取ms级别时间时,需注意溢出问题。

1)首先来看一下函数原型:

int gettimeofday(struct timeval *tv, struct timezone *tz)

其中结构体struct timeval定义如下:

struct timeval {
    time_t      tv_sec;     /* seconds */
    suseconds_t tv_usec;    /* microseconds */
};

其中time_t和suseconds_t都是long int类型。

2)、在利用tv_sec和tv_usec计算毫秒数时,需要注意溢出的问题。

long long getmstime()

{

struct timeval tv;

long long tm;

gettimeofday(& tv, NULL);

tm = (long long)tv.tv_sec *1000 + tv.tv_usec /1000;

return tm;

}

通过以上方式可以获得系统当前的毫秒数,这里需要注意的是,当系统为32位时msec变量需要定义为long long类型,因为对于32位系统来数,long的长度为32位,取值范围为-2,147,483,648~2,147,483,647,会溢出。

如果定义long或者int,使用s量级时间单位,可以到2039年不溢出;

如果定义long long,无论使用s量级时间单位还是ms量级时间单位,都不用考虑时间溢出问题;

2、localtime

获取当前的时间;

u32 getlocaltime()

{

time_t timep;

struct tm *p;

time(&timep);

p=localtime(&timep);

printf("%d-%d-%d %d:%d:%d\n",

(1900 + p->tm_year),(1 + p->tm_mon),p->tm_mday,(p->tm_hour+12),p->tm_min,p->tm_sec);

return 0;

}


Logo

更多推荐