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. Codeforces Round #275 (Div. 1)A. Diverse Permutation 构造

    Codeforces Round #275 (Div. 1)A. Diverse Permutation Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 ht ...

  2. Apache 如何反向代理tomcat并且实现Session保持

    简介 LAMT=Linux+Apache+MySQL+Tomcat: Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器: 在中小型系统和并发访问用户不是很多的场合下 ...

  3. C 常量的类型

    http://bbs.csdn.net/topics/380028485 整型常量的类型是下列相应表中第一个能表示其值的类型: int --> long int --> long long ...

  4. Jquery ajax传递复杂参数给WebService

    参考: http://www.cnblogs.com/kingge/archive/2011/08/04/2127642.html http://www.cnblogs.com/micromouse/ ...

  5. panic: reflect.Value.Interface: cannot return value obtained from unexported field or method

    go的结构体中私有的属性, 即使反射也获取不到

  6. 线程系列07,使用lock语句块或Interlocked类型方法保证自增变量的数据同步

    假设多个线程共享一个静态变量,如果让每个线程都执行相同的方法每次让静态变量自增1,这样的做法线程安全吗?能保证自增变量数据同步吗?本篇体验使用lock语句块和Interlocked类型方法保证自增变量 ...

  7. java jxl excel 导入导出的 总结(建立超链接,以及目录sheet的索引)

    最近项目要一个批量导出功能,而且要生成一个单独的sheet页,最后后面所有sheet的索引,并且可以点击进入连接.网上搜索了一下,找到一个方法,同时把相关的excel导入导出操作记录一下!以便以后使用 ...

  8. 2008技术内幕:T-SQL语言基础 联接查询摘记

    续 2008技术内幕:T-SQL语言基础 单表查询摘记 第三章 联接查询 Microsoft SQL Server 2008 支持四种表运算符 join(ANSI标准).apply(T-SQL扩展). ...

  9. 同步FIFO的设计

    module scfifo #( , ) ( input clk, input rst_n, input wren, input rden, :] din, :] dout, output full, ...

  10. 数学图形(1.2)Sin曲线

    相关软件参见:数学图形可视化工具,使用自己定义语法的脚本代码生成数学图形.该软件免费开源.QQ交流群: 367752815 Sin曲线 vertices = x = *PI) to (*PI) y = ...