linux下常用的几个时间函数:time,gettimeofday,clock_gettime,_ftime
- time()提供了秒级的精确度
- 1、头文件 <time.h>
- 2、函数原型
- time_t time(time_t * timer)
- 函数返回从TC1970-1-1 0:0:0开始到现在的秒数
- 用time()函数结合其他函数(如:localtime、gmtime、asctime、ctime)可以获得当前系统时间或是标准时间。
- #include <time.h>
- #include <stdio.h>
- int main(void)
- {
- time_t t;
- t = time(NULL);
- printf("The number of seconds since January 1, 1970 is %ld",t);
- return 0;
- }
- #include <stdio.h>
- #include <stddef.h>
- #include <time.h>
- int main(void)
- {
- time_t timer;//time_t就是long int 类型
- struct tm *tblock;
- timer = time(NULL);//这一句也可以改成time(&timer);
- tblock = localtime(&timer);
- printf("Local time is: %s/n",asctime(tblock));
- return 0;
- }
- gettimeofday()提供了微秒级的精确度
- 1、头文件 <time.h>
- 2、函数原型
- int gettimeofday(struct timeval *tv, struct timezone *tz);
- gettimeofday()会把目前的时间由tv所指的结构返回,当地时区的信息则放到tz所指的结构中(可用NULL)。
- 参数说明:
- timeval结构定义为:
- struct timeval
- {
- long tv_sec; /*秒*/
- long tv_usec; /*微秒*/
- };
- timezone 结构定义为:
- struct timezone
- {
- int tz_minuteswest; /*和Greenwich 时间差了多少分钟*/
- int tz_dsttime; /*日光节约时间的状态*/
- };
- 上述两个结构都定义在/usr/include/sys/time.h。tz_dsttime 所代表的状态如下
- DST_NONE /*不使用*/
- DST_USA /*美国*/
- DST_AUST /*澳洲*/
- DST_WET /*西欧*/
- DST_MET /*中欧*/
- DST_EET /*东欧*/
- DST_CAN /*加拿大*/
- DST_GB /*大不列颠*/
- DST_RUM /*罗马尼亚*/
- DST_TUR /*土耳其*/
- DST_AUSTALT /*澳洲(1986年以后)*/
- 返回值: 成功则返回0,失败返回-1,错误代码存于errno。附加说明EFAULT指针tv和tz所指的内存空间超出存取权限。
- #include<stdio.h>
- #include<time.h>
- int main(void)
- {
- struct timeval tv;
- struct timezone tz;
- gettimeofday (&tv , &tz);
- printf(“tv_sec; %d/n”, tv,.tv_sec) ;
- printf(“tv_usec; %d/n”,tv.tv_usec);
- printf(“tz_minuteswest; %d/n”, tz.tz_minuteswest);
- printf(“tz_dsttime, %d/n”,tz.tz_dsttime);
- return 0;
- }
- clock_gettime( ) 提供了纳秒级的精确度
- 1、头文件 <time.h>
- 2、编译&链接。在编译链接时需加上 -lrt ;因为在librt中实现了clock_gettime函数
- 3、函数原型
- int clock_gettime(clockid_t clk_id, struct timespect *tp);
- 参数说明:
- clockid_t clk_id 用于指定计时时钟的类型,有以下4种:
- CLOCK_REALTIME:系统实时时间,随系统实时时间改变而改变,即从UTC1970-1-1 0:0:0开始计时,中间时刻如果系统时间被用户该成其他,则对应的时间相应改变
- CLOCK_MONOTONIC:从系统启动这一刻起开始计时,不受系统时间被用户改变的影响
- CLOCK_PROCESS_CPUTIME_ID:本进程到当前代码系统CPU花费的时间
- CLOCK_THREAD_CPUTIME_ID:本线程到当前代码系统CPU花费的时间
- struct timespect *tp用来存储当前的时间,其结构如下:
- struct timespec
- {
- time_t tv_sec; /* seconds */
- long tv_nsec; /* nanoseconds */
- };
- 返回值。0成功,-1失败
- #include<stdio.h>
- #include<time.h>
- int main()
- {
- struct timespec ts;
- clock_gettime(CLOCK_REALTIME, &ts);
- printf("CLOCK_REALTIME: %d, %d", ts.tv_sec, ts.tv_nsec);
- clock_gettime(CLOCK_MONOTONIC, &ts);//打印出来的时间跟 cat /proc/uptime 第一个参数一样
- printf("CLOCK_MONOTONIC: %d, %d", ts.tv_sec, ts.tv_nsec);
- clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &ts);
- printf("CLOCK_PROCESS_CPUTIME_ID: %d, %d", ts.tv_sec, ts.tv_nsec);
- clock_gettime(CLOCK_THREAD_CPUTIME_ID, &ts);
- printf("CLOCK_THREAD_CPUTIME_ID: %d, %d", ts.tv_sec, ts.tv_nsec);
- printf("/n%d/n", time(NULL));
- return 0;
- }
- /proc/uptime里面的两个数字分别表示:
- the uptime of the system (seconds), and the amount of time spent in idle process (seconds).
- 把第一个数读出来,那就是从系统启动至今的时间,单位是秒
- _ftime()提供毫秒级的精确度
- 1、头文件 <sys/types.h> and <sys/timeb.h>
- 2、函数原型
- void _ftime(struct _timeb *timeptr);
- 参数说明:
- struct _timeb
- {
- time_t time;
- unsigned short millitm;
- short timezone;
- short dstflag;
- };
- #include <stdio.h>
- #include <sys/timeb.h>
- #include <time.h>
- void main( void )
- {
- struct _timeb timebuffer;
- char *timeline;
- _ftime( &timebuffer );
- timeline = ctime( & ( timebuffer.time ) );
- printf( "The time is %.19s.%hu %s", timeline, timebuffer.millitm, &timeline[20] );
- }
linux下常用的几个时间函数:time,gettimeofday,clock_gettime,_ftime的更多相关文章
- linux下常用命令备忘
转自:Linux 命令集锦 linux下查看监听端口对应的进程 # lsof -i:9000 # lsof -Pnl +M -i4 如果退格键变成了:"^h". 终端连接unix删 ...
- 20145239 Linux下常用的ls命令总结
20145239 Linux下常用的ls命令总结 通过学习本周的教学视频和要求掌握的内容,发现ls命令被使用的次数非常多,但作为一个初学者,可能我只会ls或者顶多ls -l两种用法.但其实ls是一个非 ...
- Linux下常用压缩 解压命令和压缩比率对比
常用的格式有:tar, tar.gz(tgz), tar.bz2, 不同方式,压缩和解压方式所耗CPU时间和压缩比率也差异也比较大. 1. tar只是打包动作,相当于归档处理,不做压缩:解压也一样,只 ...
- linux下常用关机命令
linux下常用的关机命令有:shutdown.halt.poweroff.init:重启命令有:reboot.下面本文就主要介绍一些常用的关机命令以及各种关机命令之间的区别和具体用法. 首先来看一下 ...
- MongoDB在Linux下常用优化设置
MongoDB在Linux下常用优化设置 以下是一些MongoDB推荐的常用优化设置.在生产环境下选取合适的参数值,例如预读值和默认文件描述符数目等,会对系统性能有很大的影响. 1.关闭数据库文件的 ...
- Linux下用C获取当前时间
Linux下用C获取当前时间,具体如下: 代码(可以把clock_gettime换成time(NULL)) ? 1 2 3 4 5 6 7 8 9 10 void getNowTime() { ti ...
- linux下常用的截图、录屏工具
录屏: 在linux下常用的录屏工具有5种,可以baidu或者google下喔,我选用的是recordMydesktop,使用非常方便,用时注意先把每秒桢数调高,否则效果必然很差. 在ubuntu下可 ...
- Linux下常用的ftp操作命令
Linux下常用的ftp操作命令 =========== 完美的分割线 ============= 1.登陆ftp服务器 ftp [IP] [PORT] # 登陆ftp服务器,本机登陆可以不写IP 实 ...
- Linux下常用压缩 解压命令与压缩比率对比
常用的格式有:tar, tar.gz(tgz), tar.bz2, 不同方式,压缩和解压方式所耗CPU时间和压缩比率也差异也比较大. 1. tar只是打包动作,相当于归档处理,不做压缩:解压也一样,只 ...
随机推荐
- 超级迷宫之NABCD
模式之一:双人模式 N:基于双人之间的竞争与协作,朋友之间可以有一个竞争比赛,一决高下,男女朋友之间适合双人协作模式,共同完成游戏. A:双人竞争模式为双人同起点或不同起点来进行游戏,在竞争的紧张压力 ...
- java语言复制数组的四种方法
JAVA语言的下面几种数组复制方法中,哪个效率最高? B.效率:System.arraycopy > clone > Arrays.copyOf > for循环 1.System.a ...
- IO文件的读取,以及写入文件内容
package zxc; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.Fi ...
- DPDK实例程序:testpmd
用户手册:https://doc.dpdk.org/guides/testpmd_app_ug/index.html 还不错的入门:http://syswift.com/188.html 我的运行情况 ...
- 结对作业——web四则运算
目录: 一.Coding.net项目地址 二.PSP 三.接口设计 四.接口实现 五.性能分析 六.单元测试 七.异常处理 八.模块设计 九.模块对接 十.结对 十一.思考 十二.PSP 网站:htt ...
- java8之重新认识HashMap(转自美团技术团队)
java8之重新认识HashMap 摘要 HashMap是Java程序员使用频率最高的用于映射(键值对)处理的数据类型.随着JDK(JavaDevelopmet Kit)版本的更新,JDK1.8对Ha ...
- 课堂alpha发布
项目组名:奋斗吧兄弟 今天七组对于各自项目现有的成果进行了alpha发布,下面是我的一些感想. 天天向上团队的连连看游戏: 令我印象最深的是天天向上团队的连连看项目,他们目前能展示给我们的是核心的连连 ...
- 微信公众平台实现获取用户OpenID的方法
这篇文章主要介绍了微信公众平台实现获取用户OpenID的方法,需要开发人员经过微信授权后获取高级接口才能使用此功能,用户OpenID对于微信公众平台建设有着非常广泛的用途,需要的朋友可以参考下 本文实 ...
- 开发者应该掌握的Java代码优化技能
就像鲸鱼吃虾米一样,也许吃一个两个虾米对于鲸鱼来说作用不大,但是吃的虾米多了,鲸鱼自然饱了. 代码优化一样,也许一个两个的优化,对于提升代码的运行效率意义不大,但是只要处处都能注意代码优化,总体来说对 ...
- POJ3177_Redundant Paths
给你一个无向图,求至少加入多少条边,使得整个图是双联通的. 通过枚举题意,发现重边是不算的,直接去掉. 首先把那些边是桥计算出来,把位于同一个连通分量里面的点缩成一个点(并查集),然后计算缩点后有多少 ...