最近需要测算软件计算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 <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结构自己查吧
-
-
-
-
附录:
-
-------------------------------------------------
-
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 %s\n",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
-
};
阅读(13358) | 评论(0) | 转发(1) |