linux 获取时间差
来源:互联网 发布:亨廷顿 谈中国知乎 编辑:程序博客网 时间:2024/06/06 02:05
[转]linux下获得时间差,精确到微秒级别 2008-03-12 10:05:45
分类:
最近需要测算软件计算FFT所需要的时间,所收集参考的资料:
#include <stdio.h>
#include <stdlib.h> /* 包含标准库头文件 */
#include <sys/time.h>
int main(int argc, char **argv)
{
struct timeval start,stop,diff;
gettimeofday(&start,0);
//做你要做的事...
gettimeofday(&stop,0);
timeval_subtract(&diff,&start,&stop);
printf("总计用时:%d 微秒n",diff.tv_usec);
}
/**
* 计算两个时间的间隔,得到时间差
* @param struct timeval* resule 返回计算出来的时间
* @param struct timeval* x 需要计算的前一个时间
* @param struct timeval* y 需要计算的后一个时间
* return -1 failure ,0 success
**/
int timeval_subtract(struct timeval* result, struct timeval* x, struct timeval* y)
{
int nsec;
if ( x->tv_sec>y->tv_sec )
return -1;
if ( (x->tv_sec==y->tv_sec) && (x->tv_usec>y->tv_usec) )
return -1;
result->tv_sec = ( y->tv_sec-x->tv_sec );
result->tv_usec = ( y->tv_usec-x->tv_usec );
if (result->tv_usec<0)
{
result->tv_sec--;
result->tv_usec+=1000000;
}
return 0;
}
#include <stdlib.h> /* 包含标准库头文件 */
#include <sys/time.h>
int main(int argc, char **argv)
{
struct timeval start,stop,diff;
gettimeofday(&start,0);
//做你要做的事...
gettimeofday(&stop,0);
timeval_subtract(&diff,&start,&stop);
printf("总计用时:%d 微秒n",diff.tv_usec);
}
/**
* 计算两个时间的间隔,得到时间差
* @param struct timeval* resule 返回计算出来的时间
* @param struct timeval* x 需要计算的前一个时间
* @param struct timeval* y 需要计算的后一个时间
* return -1 failure ,0 success
**/
int timeval_subtract(struct timeval* result, struct timeval* x, struct timeval* y)
{
int nsec;
if ( x->tv_sec>y->tv_sec )
return -1;
if ( (x->tv_sec==y->tv_sec) && (x->tv_usec>y->tv_usec) )
return -1;
result->tv_sec = ( y->tv_sec-x->tv_sec );
result->tv_usec = ( y->tv_usec-x->tv_usec );
if (result->tv_usec<0)
{
result->tv_sec--;
result->tv_usec+=1000000;
}
return 0;
}
--------------------------------------------------
#include <sys/time.h>
#include <unistd.h>
int gettimeofday(struct timeval *tv,struct timezone *tz);
功能:将目前的时间以tv所指的结构返回。
struct timeval{
long tv_sec;//秒
long tv_usec;//微秒
};
将其中的tv_usec转换到毫秒即可。
timezone结构自己查吧
#include <unistd.h>
int gettimeofday(struct timeval *tv,struct timezone *tz);
功能:将目前的时间以tv所指的结构返回。
struct timeval{
long tv_sec;//秒
long tv_usec;//微秒
};
将其中的tv_usec转换到毫秒即可。
timezone结构自己查吧
附录:
-------------------------------------------------
Linux下获得系统时间的C语言的实现方法
#include<time.h> //C语言的头文件
#include<stdio.h> //C语言的I/O
void main()
{
time_t now; //实例化time_t结构
struct tm *timenow; //实例化tm结构指针
time(&now);
//time函数读取现在的时间(国际标准时间非北京时间),然后传值给now
timenow = localtime(&now);
//localtime函数把从time取得的时间now换算成你电脑中的时间(就是你设置的地区)
printf("Local time is %sn",asctime(timenow));
//上句中asctime函数把时间转换成字符,通过printf()函数输出
}
注释:time_t是一个在time.h中定义好的结构体。而tm结构体的原形如下:
struct tm
{
int tm_sec;//seconds 0-61
int tm_min;//minutes 1-59
int tm_hour;//hours 0-23
int tm_mday;//day of the month 1-31
int tm_mon;//months since jan 0-11
int tm_year;//years from 1900
int tm_wday;//days since Sunday, 0-6
int tm_yday;//days since Jan 1, 0-365
int tm_isdst;//Daylight Saving time indicator
};
#include<time.h> //C语言的头文件
#include<stdio.h> //C语言的I/O
void main()
{
time_t now; //实例化time_t结构
struct tm *timenow; //实例化tm结构指针
time(&now);
//time函数读取现在的时间(国际标准时间非北京时间),然后传值给now
timenow = localtime(&now);
//localtime函数把从time取得的时间now换算成你电脑中的时间(就是你设置的地区)
printf("Local time is %sn",asctime(timenow));
//上句中asctime函数把时间转换成字符,通过printf()函数输出
}
注释:time_t是一个在time.h中定义好的结构体。而tm结构体的原形如下:
struct tm
{
int tm_sec;//seconds 0-61
int tm_min;//minutes 1-59
int tm_hour;//hours 0-23
int tm_mday;//day of the month 1-31
int tm_mon;//months since jan 0-11
int tm_year;//years from 1900
int tm_wday;//days since Sunday, 0-6
int tm_yday;//days since Jan 1, 0-365
int tm_isdst;//Daylight Saving time indicator
};
0
上一篇:DataTable,DataView和DataGrid比较
下一篇:[转]主设备号与次设备号
- linux 获取时间差
- linux驱动里获取时间差
- linux中获取系统时间差
- Linux下获取毫秒级时间差
- Linux下获取毫秒级时间差
- linux获取时间函数及计算时间差
- Linux下获取时间差(毫秒级)
- Linux 获取时间差精确到ms
- linux获取时间函数及计算时间差
- 获取时间差
- 获取时间差(累积)
- 精确获取时间差
- c# 获取时间差
- PHP获取时间差函数
- 两个日期,获取时间差
- 获取日期的时间差
- c# 获取时间差
- 获取时间差(累积)
- 51中断
- C语言数据类型
- Codeforces #163 Div2 E
- 网络程序设计——ping命令的实现
- 实现顺序队列各种基本运算的算法
- linux 获取时间差
- 教你如何训练和提高自己的情商
- UML 概述
- Python入门解析篇
- 荷叶茶的制作
- AMPS:内存管理模块源码解读(二)
- Python多线程实例
- ISE Simulator综合后仿真 - How do you run Post Synthesis Simulation in ISE Project Navigator?
- 实现顺序串各种基本运算的算法