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只是打包动作,相当于归档处理,不做压缩:解压也一样,只 ...
随机推荐
- 树莓派与Arduino Leonardo使用NRF24L01无线模块通信之基于RF24库 (一) 配置与测试
引脚连接说明 与树莓派的连线 NRF24L01 => 树莓派 GND => GND VCC => 3.3V CE = ...
- Beta阶段——3
一.提供当天站立式会议照片一张: 二. 每个人的工作 (有work item 的ID) (1) 昨天已完成的工作: 今天主要是对管理员功能进行改进,解决了Alpha阶段出现的一些问题 (2) 今天计划 ...
- CentOS 7.2修改网卡名称
#!/bin/bash #Centos7.2修改网卡名称ens33为eth0 #2017/05/19 if [ -f /etc/sysconfig/grub ];then cd cp /etc/sys ...
- 解决将easyui里的combobox里的输入框下拉列表变为空值
jQuery easyui官网上有一个方法是 :clear方法,这个方法说是能清除数据,但我测试了,结果它确实清楚了(但他清除的只是输入框显示的数据,没有清除所有的数据),在这里巧妙的用 它加载数据的 ...
- C# 窗体文件下的 MainForm.cs,MainForm.Designer.cs,MainForm.resx,是什么,干什么
Form.cs和Form.Designer.cs其实是一个类,Visual Studio为了让我们方便管理,用partial关键字把窗体类给拆开了, Form.Designer.cs存放的是窗体的布局 ...
- 清理elasticsearch的索引
curl -XDELETE 'http://172.16.1.16:9200/logstash-2013.03.*' 清理掉了所有 3月份的索引文件,其中*是通配符 下面是主页上的详细介绍,其他部分可 ...
- HDU4436_str2int
很好的一个题目.对于理解后缀自动机很有用. 题目给你若干数字串,总长度不超过100000,任意一个串的任意一个子串都可以拿出来单独的作为一个数字.同一个数字只算一次. 问所有不同数字的和为多少? 嗯嗯 ...
- eclipse中添加配置文件夹config
1. 在项目上右键->Build path->Configure Build Path->Source下的Add Folder,如图 2. 在弹出框中,Create New Fold ...
- 机器学习经典论文/survey合集
Active Learning Two Faces of Active Learning, Dasgupta, 2011 Active Learning Literature Survey, Sett ...
- NOIP赛前集训营-提高组(第一场)#A 中位数
题目描述 小N得到了一个非常神奇的序列A.这个序列长度为N,下标从1开始.A的一个子区间对应一个序列,可以由数对[l,r]表示,代表A[l], A[l + 1], ..., A[r]这段数.对于一 ...