Linux下使用clock_gettime给程序计时


#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <time.h> int main(int argc, char *argv[])
{ struct timeval tv;
char mytime[] = ""; gettimeofday(&tv,NULL);
strftime(mytime,sizeof(mytime),"%Y-%m-%d %T",localtime(&tv.tv_sec)); printf("Time:%s\n",mytime); return ; } http://blog.csdn.net/yuxuyongb/article/details/16338771
一、linux下时间表示方式
linux下存储时间常见的有两种存储方式:
1.从1970年到现在经过了多少秒 (time_t类型)
2.用一个结构来分别存储年月日时分秒 (tm结构体)
tm结构体如下:
struct tm
{
int tm_sec; /*秒,正常范围0-59, 但允许至61*/
int tm_min; /*分钟,0-59*/
int tm_hour; /*小时, 0-23*/
int tm_mday; /*日,即一个月中的第几天,1-31*/
int tm_mon; /*月, 从一月算起,0-11*/ 1+p->tm_mon;
int tm_year; /*年, 从1900至今已经多少年*/ 1900+ p->tm_year;
int tm_wday; /*星期,一周中的第几天, 从星期日算起,0-6*/
int tm_yday; /*从今年1月1日到目前的天数,范围0-365*/
int tm_isdst;
};

PS:年份是从1900年起至今多少年,而不是直接存储如2013年,月份从0开始的,0表示一月,星期也是从0开始的, 0表示星期日,1表示星期一。

二、linux下时间类型的相互转换
由上述可知,linux下常用的两种类型就是time_t和tm。下面根据程序来对两者完成一个相互转换。

1.time_t格式转换成tm格式

int main()
{
    time_t timetTime;
    struct tm *pTmTime;
    char   szTime[24] = {0};
   
    //获取当前系统时间
    timetTime = time(NULL);
    printf("timetTime=%d\n", timetTime);

//time_t 结构转换成tm结构
    pTmTime = localtime(&timetTime);

//验证tm类型数据是否正确
    snprintf(szTime, sizeof(szTime)-1,
     "%d-%02d-%02d %02d:%02d:%02d",
        pTmTime->tm_year+1900,
        pTmTime->tm_mon+1,
        pTmTime->tm_mday,
        pTmTime->tm_hour,
        pTmTime->tm_min,
        pTmTime->tm_sec);
    printf("szTime=%s\n", szTime);
   
    return 0; 
}

输出结果:
timetTime=1384486705
szTime=2013-11-15 11:38:25

2.tm格式转换成time_t格式

int main()
{

struct    tm tmTime;
 time_t    timetTime;
 
 //定义一个时间
 int year = 2013;
 int month = 11;
 int day = 15;
 int hour = 10;
 int min = 30;
 int sec = 30;

//构建tm结构体
 tmTime.tm_year = year-1900;
 tmTime.tm_mon = month-1;
 tmTime.tm_mday = day;
 tmTime.tm_hour = hour;
 tmTime.tm_min  = min;
 tmTime.tm_sec  = sec;

//tm结构转换成time_t结构
 timetTime = mktime(&tmTime);
 printf("timetTime=%d\n", timetTime);
 //用ctime函数校验下,上面转换是否正确
 printf("After transfer, time is: %s\n", ctime((time_t*)&timetTime));

return 0;
}

输出结果:
timetTime=1384482630
After transfer, time is: Fri Nov 15 10:30:30 2013

三、总结
上述程序中用到的函数:
1. time_t time(time_t *t);
获取当前系统time_t时间,其返回值是自1970来的秒数值。
2. stuct tm* localtime(const time_t *timep);
将time_t时间转换成tm时间,输入值是time_t结构的指针,返回值是tm类型的指针。
3.time_t mktime(struct tm* timeptr);
将tm时间转换为time_t时间,输入值是tm类型的地址,返回值是time_t类型。
4.char *ctime(const time_t *timep);
将time_t类型所代表的时间转换成字符串形式的时间,输入为time_t类型地址。

四、拓展
上述是我个人平时所用到的,于我而言够用了,如果需要更为深入的学习,
推荐写本文时参考的这篇文章:http://blog.csdn.net/love_gaohz/article/details/6637625
asctime,gmtime函数也时常见到,顺便再mark一下

char *asctime(const struct tm* timeptr);
将tm结构中的信息转换为字符串形式的时间

struct tm* gmtime(const time_t *timep);
将time_t表示的时间转换为tm结构时间(与localtime类似,但是是没有经过时区转换的UTC时间)

double difftime(time_t time1, time_t time2);
返回两个时间相差的秒数


一、linux下时间表示方式
linux下存储时间常见的有两种存储方式:
1.从1970年到现在经过了多少秒 (time_t类型)
2.用一个结构来分别存储年月日时分秒 (tm结构体)
tm结构体如下:

  1. struct tm
  2. {
  3. int tm_sec;  /*秒,正常范围0-59, 但允许至61*/
  4. int tm_min;  /*分钟,0-59*/
  5. int tm_hour; /*小时, 0-23*/
  6. int tm_mday; /*日,即一个月中的第几天,1-31*/
  7. int tm_mon;  /*月, 从一月算起,0-11*/  1+p->tm_mon;
  8. int tm_year;  /*年, 从1900至今已经多少年*/  1900+ p->tm_year;
  9. int tm_wday; /*星期,一周中的第几天, 从星期日算起,0-6*/
  10. int tm_yday; /*从今年1月1日到目前的天数,范围0-365*/
  11. int tm_isdst;
  12. };

PS:年份是从1900年起至今多少年,而不是直接存储如2013年,月份从0开始的,0表示一月,星期也是从0开始的, 0表示星期日,1表示星期一。

二、linux下时间类型的相互转换
由上述可知,linux下常用的两种类型就是time_t和tm。下面根据程序来对两者完成一个相互转换。

1.time_t格式转换成tm格式

  1. int main()
  2. {
  3. time_t timetTime;
  4. struct tmtm *pTmTime;
  5. char   szTime[24] = {0};
  6. //获取当前系统时间
  7. timetTime = time(NULL);
  8. printf("timetTime=%d\n", timetTime);
  9. //time_t 结构转换成tm结构
  10. pTmTime = localtime(&timetTime);
  11. //验证tm类型数据是否正确
  12. snprintf(szTime, sizeof(szTime)-1,
  13. "%d-%02d-%02d %02d:%02d:%02d",
  14. pTmTime->tm_year+1900,
  15. pTmTime->tm_mon+1,
  16. pTmTime->tm_mday,
  17. pTmTime->tm_hour,
  18. pTmTime->tm_min,
  19. pTmTime->tm_sec);
  20. printf("szTime=%s\n", szTime);
  21. return 0;
  22. }

输出结果:
timetTime=1384486705
szTime=2013-11-15 11:38:25

2.tm格式转换成time_t格式

  1. int main()
  2. {
  3. struct    tm tmTime;
  4. time_t    timetTime;
  5. //定义一个时间
  6. int year = 2013;
  7. int month = 11;
  8. int day = 15;
  9. int hour = 10;
  10. int min = 30;
  11. int sec = 30;
  12. //构建tm结构体
  13. tmTime.tm_year = year-1900;
  14. tmTime.tm_mon = month-1;
  15. tmTime.tm_mday = day;
  16. tmTime.tm_hour = hour;
  17. tmTime.tm_min  = min;
  18. tmTime.tm_sec  = sec;
  19. //tm结构转换成time_t结构
  20. timetTime = mktime(&tmTime);
  21. printf("timetTime=%d\n", timetTime);
  22. //用ctime函数校验下,上面转换是否正确
  23. printf("After transfer, time is: %s\n", ctime((time_t*)&timetTime));
  24. return 0;
  25. }

输出结果:
timetTime=1384482630
After transfer, time is: Fri Nov 15 10:30:30 2013

三、总结
上述程序中用到的函数:
1. time_t time(time_t *t);
获取当前系统time_t时间,其返回值是自1970来的秒数值。
2. stuct tm* localtime(const time_t *timep);
将time_t时间转换成tm时间,输入值是time_t结构的指针,返回值是tm类型的指针。
3.time_t mktime(struct tm* timeptr);
将tm时间转换为time_t时间,输入值是tm类型的地址,返回值是time_t类型。
4.char *ctime(const time_t *timep);
将time_t类型所代表的时间转换成字符串形式的时间,输入为time_t类型地址。

四、拓展
上述是我个人平时所用到的,于我而言够用了,如果需要更为深入的学习,
推荐写本文时参考的这篇文章:http://blog.csdn.net/love_gaohz/article/details/6637625
asctime,gmtime函数也时常见到,顺便再mark一下

char *asctime(const struct tm* timeptr);
将tm结构中的信息转换为字符串形式的时间

struct tm* gmtime(const time_t *timep);
将time_t表示的时间转换为tm结构时间(与localtime类似,但是是没有经过时区转换的UTC时间)

double difftime(time_t time1, time_t time2);
返回两个时间相差的秒数

/********************************************************************************
* Name: GxCore_GetTickTime
*
* Purpose: This functions get the tick time of the machine its on
********************************************************************************/
int32_t GxCore_GetTickTime(GxTime *time_struct)
{
struct timespec sys_time;
clock_gettime(CLOCK_MONOTONIC,&sys_time);
time_struct->seconds = sys_time.tv_sec;
time_struct->microsecs = sys_time.tv_nsec/1000;
return GXCORE_SUCCESS; } SYNOPSIS
       #include <time.h>        int clock_getres(clockid_t clk_id, struct timespec *res);        int clock_gettime(clockid_t clk_id, struct timespec *tp);        int clock_settime(clockid_t clk_id, const struct timespec *tp);        Link with -lrt.        CLOCK_REALTIME
              System-wide real-time clock.  Setting this clock requires appropriate privileges.        CLOCK_MONOTONIC
              Clock that cannot be set and represents monotonic time since some unspecified starting point.        CLOCK_MONOTONIC_RAW (since Linux 2.6.28; Linux-specific)
              Similar to CLOCK_MONOTONIC, but provides access to a raw hardware-based time that is not subject to NTP adjustments.        CLOCK_PROCESS_CPUTIME_ID
              High-resolution per-process timer from the CPU.        CLOCK_THREAD_CPUTIME_ID
              Thread-specific CPU-time clock.

clock_gettime参数介绍

http://blog.163.com/cocoa_20/blog/static/2539600620110139470831/

Middleware对POSIX提供的标准计时器API进行封装,主要提供了两种类型的时钟的封装。一种是CLOCK_REALTIME,另一种是CLOCK_MONOTONIC。对与man手册的解释是:
CLOCK_REALTIME: Systemwide realtime clock. 系统范围内的实时时钟。
CLOCK_MONOTONIC:Represents monotonic time. Cannot be set. 表示单调时间,不能被设置的。

手册中解释的比较笼统。我个人的理解是:
CLOCK_REALTIME:这种类型的时钟可以反映wall clock time,用的是绝对时间,当系统的时钟源被改变,或者系统管理员重置了系统时间之后,这种类型的时钟可以
得到相应的调整,也就是说,系统时间影响这种类型的timer。
CLOCK_MONOTONIC:用的是相对时间,他的时间是通过jiffies值来计算的。该时钟不受系统时钟源的影响,只受jiffies值的影响

建议使用:
CLOCK_MONOTONIC这种时钟更加稳定,不受系统时钟的影响。如果想反映wall clock time,就使用CLOCK_REALTIME。

关于时间的博文:

浅谈时间函数gettimeofday的成本

Linux时间子系统之六:高精度定时器(HRTIMER)的原理和实现

timer_slack_ns

【进程管理】系统调用nanosleep()和pause()u

Linux下时间格式转换及获取方法的更多相关文章

  1. linux环境下deb格式 转换成rpm格式

    linux环境下deb格式 转换成rpm格式 使用alien工具转换deb格式到rpm格式 alien_8.87.tar.gz 下载alien_8.87.tar.gz [root@mysqlnode2 ...

  2. LINUX 下时间转换为秒数

    linux下时间是从1970.1.1开始算的秒数 //转来自网址 http://blog.csdn.net/wind19/article/details/6579495 $ dateTue Feb 3 ...

  3. 问题:Oracle to_date;结果:oracle常用的时间格式转换

    oracle常用的时间格式转换 1:取得当前日期是本月的第几周 SQL> select to_char(sysdate,'YYYYMMDD W HH24:MI:SS') from dual; T ...

  4. linux下各安装包的安装方法

    <转>linux下各安装包的安装方法   一.rpm包安装方式步骤: 1.找到相应的软件包,比如soft.version.rpm,下载到本机某个目录: 2.打开一个终端,su -成root ...

  5. Linux下搭建iSCSI共享存储的方法 Linux-IO Target 方式CentOS7-1810下实现

    iSCSI(internet SCSI)技术由IBM公司研究开发,是一个供硬件设备使用的.可以在IP协议的上层运行的SCSI指令集,这种指令集合可以实现在IP网络上运行SCSI协议,使其能够在诸如高速 ...

  6. Linux下搭建iSCSI共享存储的方法 Linux-IO Target 方式 Debian9.5下实现

    iSCSI(internet SCSI)技术由IBM公司研究开发,是一个供硬件设备使用的.可以在IP协议的上层运行的SCSI指令集,这种指令集合可以实现在IP网络上运行SCSI协议,使其能够在诸如高速 ...

  7. Linux下进程通信的八种方法

    Linux下进程通信的八种方法:管道(pipe),命名管道(FIFO),内存映射(mapped memeory),消息队列(message queue),共享内存(shared memory),信号量 ...

  8. Sql日期时间格式转换;取年 月 日,函数:DateName()、DATEPART()

    一.sql server2000中使用convert来取得datetime数据类型样式(全) 日期数据格式的处理,两个示例: CONVERT(varchar(16), 时间一, 20) 结果:2007 ...

  9. sql 日期时间格式转换

    Sql日期时间格式转换   sql server2000中使用convert来取得datetime数据类型样式(全) 日期数据格式的处理,两个示例: CONVERT(varchar(16), 时间一, ...

随机推荐

  1. Vue 生命周期方法

    一.Vue 生命周期 Vue的生命周期即是实例从创建到销毁的一个过程.之前在学习Vue的时候,看过官网的教程,但是经常用到的是mounted,所以对其他生命周期方法不是很熟悉,这里有空做个总结,也方便 ...

  2. w​x​F​o​r​m​B​u​i​l​d​e​r​初​体​验

    第一步 打开wxFormBuilder 修改工程信息并保存工程 Name: 工程名 File: 生成代码(.py)文件名 Code_generation: 生成代码类型 第二步 创建窗体 切换至for ...

  3. 三个实例演示 Java Thread Dump 日志分析(转)

    原文链接:http://www.cnblogs.com/zhengyun_ustc/archive/2013/01/06/dumpanalysis.html 转来当笔记^_^ jstack Dump ...

  4. 活动(Activity)

    一.用Log打印日志 Log.d("HelloWorldActivity", "onCreate execute"); 二.Toast用法 Toast.make ...

  5. jquery实现回车键触发事件

    键盘事件有3: keydown,keypress,keyup,分别是按下,按着没上抬,上抬键盘 . 正确代码为: $(document).keyup(function(event){ if(event ...

  6. 埃及分解:将2/n分解成为1/x+1/y的格式

    算法 古埃及以前创造出灿烂的人类文明,他们的分数表示却非常令人不解.古埃及喜欢把一个分数分解为类似: 1/a + 1/b 的格式. 这里,a 和 b 必须是不同的两个整数,分子必须为 1 比方,2/1 ...

  7. Material Design(原质化设计)视觉设计语言规范 踏得网镜像

    Android 5.0 Lollipop(棒棒糖,也就是之前的代称Android L)全面实践了谷歌最新研发的 Material Design 设计语言规范,只是该设计规范并不是仅针对移动平台. 我们 ...

  8. Spring3数据源的6种配置方法

    在Spring3中,配置DataSource的方法有五种. 第一种:beans.xml <bean id="dataSource" class="org.apach ...

  9. Android之获取sdcard卡的信息

    public static SDCardInfo getSDCardInfo() { String sDcString = android.os.Environment.getExternalStor ...

  10. json的好处-新一代数据传输利器

    JSON是一种轻量级的数据交换格式!和xml一样. 为什么不XML XML的冗余太大,不过XML阅读起来比较方面,所以并没有被json完全取代,很多时候都是并存.比如sina微博的开发平台有一个JSO ...