Chinaunix首页 | 论坛 | 博客
  • 博客访问: 230717
  • 博文数量: 75
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 848
  • 用 户 组: 普通用户
  • 注册时间: 2013-10-08 10:27
文章分类
文章存档

2014年(9)

2013年(66)

我的朋友

分类: C/C++

2013-11-12 14:46:16



通用的:clock_t和clock()
clock_t和clock()在两个平台下都能用,使用它们可以计算程序使用的cpu时间,不过windows和linux返回的时间单位不一样,一个是毫秒,一个是微秒。使用他们需要包含
示例程序如下:
#i nclude
#i nclude
#i nclude
using namespace std;
int main()
{
clock_t t;
double beginning_time, finish_time;
int i, j, k;
double sum=0,avg=0,times=10;
for(int a=0;a {
   t = clock();
   if ((clock_t)-1 == t)
   return -1; /* 调用失败,退出 */
  
   beginning_time = (double)t /1000; /* 转换成秒 */
  
   for (i = 0; i < 500; i++)
    for (j = 0; j < 500; j++)
     for (k = 0; k < 500; k++)
      ; /* 什么也不做 */
    
     t = clock();
    
     if ((clock_t)-1 == t)
      return -1; /* 调用失败,退出 */
    
     finish_time = (double)t /1000; /* 转换成秒 */
    
     sum=sum + finish_time - beginning_time;
     printf("loop spends %g seconds\n", finish_time - beginning_time);
}
avg=sum/times;
cout<

return 0;
}


windows: timeGetTime(void)
在windows平台下可以使用多媒体定时器函数DWORD timeGetTime(void),该函数定时精度为ms级,返回从Windows启动开始经过的毫秒数。
调用DWORD timeGetTime(void)函数之前必须将 Winmm.lib   和 Mmsystem.h 添加到工程中,否则在编译时提示DWORD timeGetTime(void)函数未定义。
另外:在引用2中还说到:由于使用该函数是通过查询的方式进行定时控制的,所以,应该建立定时循环来进行定时事件的控制。
示例程序如下:
#i nclude
#i nclude
#i nclude
#i nclude
#i nclude
using namespace std;
int main()
{
DWORD t1,t2;
t1=timeGetTime();
Sleep(1000);
t2=timeGetTime();
printf("begin:%ld\n",t1);        //%ld   用长整型数输出
printf("end:   %ld\n",t2);
printf("lasting:%ld\n",t2-t1);
//CTime t = CTime::GetCurrentTime();
  
return 0;
}


linux: int gettimeofday ( struct timeval * tv , struct timezone * tz )
使用gettimeofday(),需要包含,它会在timeval中返回从1970年1月1日0时0分0秒算起至今所经过的秒数和微秒数,因此理论上结果可以精确到微秒。
使用的时候,在函数开始之前和结束之后取timeval的值,相减就能得出函数使用的时间。
timeval结构定义为: 
struct timeval{ 
long tv_sec; /*秒*/ 
long tv_usec; /*微秒*/ 
}; 
gettimeofday()的其他资料,可以参考引用1。
示例程序如下:
#i nclude
#i nclude
int main()
{
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);
// int gettimeofday(struct    timeval    *tv,    struct    timezone    *tz);
return 0;
}
这里只是讲到取系统时间和计算的问题,至于毫秒级的延时问题,下次再讨论。
下面把引用1和引用2摘下来:
引用1:
C语言的标准库函数包括一系列日期和时间处理函数,它们都在头文件中说明。下面列出了这些函数。在头文件中定义了三种类型:time_t,struct tm和clock_t。
在中说明的C语言时间函数
time_t time(time_t *timer);
double difftime(time_t time1,time_t time2);
struct tm *gmtime(const time_t *timer);
struct tm *localtime(const time_t *timer);
char *asctime(const struct tm *timeptr);
char *ctime(const time_t *timer);
size_t strftime(char *s,size_t maxsize,const char *format,const struct tm *timeptr);
time_t mktime(struct tm *timeptr);
clock_t clock(void);
下面是我从网上收集到的时间函数集
asctime(将时间和日期以字符串格式表示) 
相关函数 
time,ctime,gmtime,localtime 
表头文件 
#i nclude 
定义函数 
char * asctime(const struct tm * timeptr); 
函数说明 
asctime()将参数timeptr所指的tm结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果以字符串形态返回。此函数已经由时区转换成当地时间,字符串格式为:"Wed Jun 30 21:49:08 1993\n" 
返回值 
若再调用相关的时间日期函数,此字符串可能会被破坏。此函数与ctime不同处在于传入的参数是不同的结构。 
附加说明 
返回一字符串表示目前当地的时间日期。 
范例 
#i nclude 
main() 

time_t timep; 
time (&timep); 
printf("%s",asctime(gmtime(&timep))); 

执行 
Sat Oct 28 02:10:06 2000 
 
ctime(将时间和日期以字符串格式表示) 
相关函数 
time,asctime,gmtime,localtime 
表头文件 
#i nclude 
定义函数 
char *ctime(const time_t *timep); 
函数说明 
ctime ()将参数timep所指的time_t结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果以字符串形态返回。此函数已经由时区转换成当地时间,字符串格式为"Wed Jun 30 21 :49 :08 1993\n"。若再调用相关的时间日期函数,此字符串可能会被破坏。 
返回值 
返回一字符串表示目前当地的时间日期。 
范例 
#i nclude 
main() 

time_t timep; 
time (&timep); 
printf("%s",ctime(&timep)); 

执行 
Sat Oct 28 10 : 12 : 05 2000 
 
gettimeofday(取得目前的时间) 
相关函数 
time,ctime,ftime,settimeofday 
表头文件 
#i nclude 
#i nclude 
定义函数 
int gettimeofday ( struct timeval * tv , struct timezone * tz ) 
函数说明 
gettimeofday()会把目前的时间有tv所指的结构返回,当地时区的信息则放到tz所指的结构中。 
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所指的内存空间超出存取权限。 
范例 
#i nclude 
#i nclude 
main(){ 
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); 

执行 
tv_sec: 974857339 
tv_usec:136996 
tz_minuteswest:-540 
tz_dsttime:0 
 
gmtime(取得目前时间和日期) 
相关函数 
time,asctime,ctime,localtime 
表头文件 
#i nclude 
定义函数 
struct tm*gmtime(const time_t*timep); 
函数说明 
gmtime()将参数timep 所指的time_t 结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果由结构tm返回。 
结构tm的定义为 
struct tm 

int tm_sec; 
int tm_min; 
int tm_hour; 
int tm_mday; 
int tm_mon; 
int tm_year; 
int tm_wday; 
int tm_yday; 
int tm_isdst; 
}; 
int tm_sec 代表目前秒数,正常范围为0-59,但允许至61秒 
int tm_min 代表目前分数,范围0-59 
int tm_hour 从午夜算起的时数,范围为0-23 
int tm_mday 目前月份的日数,范围01-31 
int tm_mon 代表目前月份,从一月算起,范围从0-11 
int tm_year 从1900 年算起至今的年数 
int tm_wday 一星期的日数,从星期一算起,范围为0-6 
int tm_yday 从今年1月1日算起至今的天数,范围为0-365 
int tm_isdst 日光节约时间的旗标 
此函数返回的时间日期未经时区转换,而是UTC时间。 
返回值 
返回结构tm代表目前UTC 时间 
范例 
#i nclude 
main(){ 
char *wday[]={"Sun","Mon","Tue","Wed","Thu","Fri","Sat"}; 
time_t timep; 
struct tm *p; 
time(&timep); 
p=gmtime(&timep); 
printf("%d%d%d",(1900+p->tm_year), (1+p->tm_mon),p->tm_mday); 
printf("%s%d;%d;%d\n", wday[p->tm_wday], p->tm_hour, p->tm_min, p->tm_sec); 

执行 
2000/10/28 Sat 8:15:38 
 
localtime(取得当地目前时间和日期) 
相关函数 
time, asctime, ctime, gmtime 
表头文件 
#i nclude 
定义函数 
struct tm *localtime(const time_t * timep); 
函数说明 
localtime()将参数timep所指的time_t结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果由结构tm返回。结构tm的定义请参考gmtime()。此函数返回的时间日期已经转换成当地时区。 
返回值 
返回结构tm代表目前的当地时间。 
范例 
#i nclude 
main(){ 
char *wday[]={"Sun","Mon","Tue","Wed","Thu","Fri","Sat"}; 
time_t timep; 
struct tm *p; 
time(&timep); 
p=localtime(&timep); /*取得当地时间*/ 
printf ("%d%d%d ", (1900+p->tm_year),( l+p->tm_mon), p->tm_mday); 
printf("%s%d:%d:%d\n", wday[p->tm_wday],p->tm_hour, p->tm_min, p->tm_sec); 

执行 
2000/10/28 Sat 11:12:22 
 
mktime(将时间结构数据转换成经过的秒数) 
相关函数 
time,asctime,gmtime,localtime 
表头文件 
#i nclude 
定义函数 
time_t mktime(strcut tm * timeptr); 
函数说明 
mktime()用来将参数timeptr所指的tm结构数据转换成从公元1970年1月1日0时0分0 秒算起至今的UTC时间所经过的秒数。 
返回值 
返回经过的秒数。 
范例 
/* 用time()取得时间(秒数),利用localtime() 
转换成struct tm 再利用mktine()将struct tm转换成原来的秒数*/ 
#i nclude 
main() 

time_t timep; 
strcut tm *p; 
time(&timep); 
printf("time() : %d \n",timep); 
p=localtime(&timep); 
timep = mktime(p); 
printf("time()->localtime()->mktime():%d\n",timep); 

执行 
time():974943297 
time()->localtime()->mktime():974943297 
 
settimeofday(设置目前时间) 
相关函数 
time,ctime,ftime,gettimeofday 
表头文件 
#i nclude 
#i nclude 
定义函数 
int settimeofday ( const struct timeval *tv,const struct timezone *tz); 
函数说明 
settimeofday()会把目前时间设成由tv所指的结构信息,当地时区信息则设成tz所指的结构。详细的说明请参考gettimeofday()。注意,只有root权限才能使用此函数修改时间。 
返回值 
成功则返回0,失败返回-1,错误代码存于errno。 
错误代码 
EPERM 并非由root权限调用settimeofday(),权限不够。 
EINVAL 时区或某个数据是不正确的,无法正确设置时间。 
 
time(取得目前的时间) 
相关函数 
ctime,ftime,gettimeofday 
表头文件 
#i nclude 
定义函数 
time_t time(time_t *t); 
函数说明 
此函数会返回从公元1970年1月1日的UTC时间从0时0分0秒算起到现在所经过的秒数。如果t 并非空指针的话,此函数也会将返回值存到t指针所指的内存。 
返回值 
成功则返回秒数,失败则返回((time_t)-1)值,错误原因存于errno中。 
范例 
#i nclude 
mian() 

int seconds= time((time_t*)NULL); 
printf("%d\n",seconds); 

执行 
9.73E+08

阅读(1130) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~