linux-时间相关结构体和函数

1、时间类型。Linux下常用的时间类型有4个:time_t,struct timeval,struct timespec,struct tm。

(1)time_t是一个长整型,一般用来表示用1970年以来的秒数。

(2)Struct timeval有两个成员,一个是秒,一个是微妙。

struct timeval linux-时间相关结构体和函数 - Teana - Teana{

            long tv_sec;        /**//* seconds */

            long tv_usec;  /**//* microseconds */

 };

(3)struct timespec有两个成员,一个是秒,一个是纳秒。

struct timespeclinux-时间相关结构体和函数 - Teana - Teana{

         time_t  tv_sec;         /**//* seconds */

         long    tv_nsec;        /**//* nanoseconds */

 };

(4)struct tm是直观意义上的时间表示方法:

struct tm linux-时间相关结构体和函数 - Teana - Teana{

        int     tm_sec;         /**//* seconds */

        int     tm_min;         /**//* minutes */

        int     tm_hour;        /**//* hours */

        int     tm_mday;        /**//* day of the month */

        int     tm_mon;         /**//* month */

        int     tm_year;        /**//* year */

        int     tm_yday;        /**//* day in the year */

        int     tm_wday;         /**//* day of the week */

        int     tm_isdst;       /**//* daylight saving time */

 };

2、 时间操作

(1) 时间格式间的转换函数

主要是 time_t、struct tm、时间的字符串格式之间的转换。看下面的函数参数类型以及返回值类型:

linux-时间相关结构体和函数 - Teana - Teanachar *asctime(const struct tm *tm);

linux-时间相关结构体和函数 - Teana - Teanachar *ctime(const time_t *timep);

linux-时间相关结构体和函数 - Teana - Teanastruct tm *gmtime(const time_t *timep);

linux-时间相关结构体和函数 - Teana - Teanastruct tm *localtime(const time_t *timep);

linux-时间相关结构体和函数 - Teana - Teanatime_t mktime(struct tm *tm);

gmtime和localtime的参数以及返回值类型相同,区别是前者返回的格林威治标准时间,后者是当地时间。

(2) 获取时间函数

两个函数,获取的时间类型看原型就知道了:

linux-时间相关结构体和函数 - Teana - Teanatime_t time(time_t *t);

linux-时间相关结构体和函数 - Teana - Teanaint gettimeofday(struct timeval *tv, struct timezone *tz);

前者获取time_t类型,后者获取struct timeval类型,因为类型的缘故,前者只能精确到秒,后者可以精确到微秒。

二、 延迟函数

主要的延迟函数有:sleep(),usleep(),nanosleep(),select(),pselect().

linux-时间相关结构体和函数 - Teana - Teanaunsigned int sleep(unsigned int seconds);

linux-时间相关结构体和函数 - Teana - Teanavoid usleep(unsigned long usec);

linux-时间相关结构体和函数 - Teana - Teanaint nanosleep(const struct timespec *req, struct timespec *rem);

linux-时间相关结构体和函数 - Teana - Teanaint select(int n, fd_set *readfds, fd_set *writefds, fd_set *exceptfds,struct timeval *timeout);

linux-时间相关结构体和函数 - Teana - Teanaint pselect(int   n,   fd_set   *readfds,  fd_set  *writefds,  fd_set *exceptfds, const struct timespec *timeout, const sigset_t *sigmask);

alarm函数是信号方式的延迟,这种方式不直观,这里不说了。

仅通过函数原型中时间参数类型,可以猜测sleep可以精确到秒级,usleep/select可以精确到微妙级,nanosleep和pselect可以精确到纳秒级。

而实际实现中,linux上的nanosleep和alarm相同,都是基于内核时钟机制实现,受linux内核时钟实现的影响,并不能达到纳秒级的精度,man nanosleep也可以看到这个说明,man里给出的精度是:Linux/i386上是10 ms ,Linux/Alpha上是1ms。

这里有一篇文章http://blog.csdn.net/zhoujunyi/archive/2007/03/30/1546330.aspx,测试了不同延迟函数之间的精确度。文章给出的结论是linux上精度最高的是select,10ms级别。我在本机器测试select和pselect相当,都达到了1ms级的精度,精度高于文章中给出的10ms,sleep在秒级以上和usleep/nanosleep相当。下面贴下我机器上1ms时候的测试结果,其他不贴了:

linux-时间相关结构体和函数 - Teana - Teanasleep           1000          0      -1000 

linux-时间相关结构体和函数 - Teana - Teanausleep           1000       2974       1974 

linux-时间相关结构体和函数 - Teana - Teanananosleep        1000       2990       1990 

linux-时间相关结构体和函数 - Teana - Teanaselect           1000        991         -9 

linux-时间相关结构体和函数 - Teana - Teanapselect           1000        990        -10 

linux-时间相关结构体和函数 - Teana - Teanagettimeofday           1000       1000          0

而使用gettimeofday循环不停检测时间,可精确微秒级,不过不适宜用来做定时器模块。

因此后面的定时期模块将选择select为延迟函数。


struct tm
{
  int tm_sec;                   /* Seconds.     [0-60] (1 leap second) */
  int tm_min;                   /* Minutes.     [0-59] */
  int tm_hour;                  /* Hours.       [0-23] */
  int tm_mday;                  /* Day.         [1-31] */
  int tm_mon;                   /* Month.       [0-11] */
  int tm_year;                  /* Year - 1900.  */
  int tm_wday;                  /* Day of week. [0-6] */
  int tm_yday;                  /* Days in year.[0-365] */
  int tm_isdst;                 /* DST.         [-1/0/1]*/

#ifdef  __USE_BSD
  long int tm_gmtoff;           /* Seconds east of UTC.  */
  __const char *tm_zone;        /* Timezone abbreviation.  */
#else
  long int __tm_gmtoff;         /* Seconds east of UTC.  */
  __const char *__tm_zone;      /* Timezone abbreviation.  */
#endif
};

在C语言中 
有time_t tm timeval等几种类型的时间
1.time_t为typedef __int64 __time64_t; 
2.struct timeval
{
      uint tv_sec;
      uint tv.usec;
}



具体操作函数
包含文件:<sys/time.h> <time.h> 

tm *gmtime(time_t * t);
time_t time(time_t *t);
char *asctime(const struct tm *timeptr);
char *ctime(const time_t *timer); 
把tm指针转换为time_t
time_t mktime(struct tm *timeptr);
localtime和gmtime的区别在于gmtime将时间转换为国际标准格式,也就是相对于1970 00:00:00开始的时间戳
而localtime是相对于本地的时区的格式。
#include<stdio.h>
#include<time.h>
#include<sys/time.h>
#include<signal.h>
#include<pthread.h>
void quit_t()
{
        printf("eixt now");
        exit(-1);
}
int main()
{
/*      struct timeval  vt;
        gettimeofday(&vt , NULL);
        while(1)
        {
                printf("%u:%u\n",vt.tv_sec,vt.tv_usec);
                sleep(2);
                signal(SIGINT, quit_t);
        }
*/

        struct tm *tt;
        time_t t = time(NULL);
        tt = gmtime(&t);
        //char *s = asctime(tt);
        printf("%d-%d-%d %d:%d:%d",tt->tm_year+1900,tt->tm_mon+1,tt->tm_mday,tt->tm_hour,tt->tm_min,tt->tm_sec);
        return 0;
}


#ifndef _TM_DEFINED 
struct tm { 
int tm_sec; /* 秒 - 取值区间为[0,59] */ 
int tm_min; /* 分 - 取值区间为[0,59] */ 
int tm_hour; /* 时 - 取值区间为[0,23] */ 
int tm_mday; /* 一个月中的日期 - 取值区间为[1,31] */ 
int tm_mon; /* 月份(从一月开始,0代表一月)- 取值区间为[0,11] */ 
int tm_year; /* 年份,其值等于实际年份减去1900 */ 
int tm_wday; /* 星期–取值区间为[0,6],其中0代表星期天,1代表星期一,以此类推 */ 
int tm_yday; /* 从每年的1月1日开始的天数 – 取值区间为[0,365],其中0代表1月1日,1代表1月2日,以此类推 */ 
int tm_isdst; /*夏令时标识符,实行夏令时的时候,tm_isdst为正。不实行夏令时的进候,tm_isdst为0;不了解情况时,tm_isdst()为负。*/ 
}; 
#define _TM_DEFINED /* 避免重复定义 tm */ 
#endif 
ANSI C标准称使用tm结构的这种时间表示为分解时间(broken-down time)。 
包含文件:<sys/time.h> <time.h> 
把tm指针转换为time_t: time_t mktime(struct tm *timeptr); 



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值