linux_c 网络开发日记(3)时间编程

时间类型

 coordinated university time (UTC):世界标准时间,也就是大家所熟知的格林威治时间(GMT).
calender time:日历时间,是从“一个标准时间点(1970年,1月1日零点)到此经历的秒数“来表示时间。


时间获取

#include<time>
time_t time(time_t *tloc)


功能:获取日历时间,即从1970/01/01/00时刻到现在所经历的秒数。


时间转换

struct tm *gmtime(const time_t *timep)
功能:将日历时间转换成格林威治时间,并保存在TM结构。
struct tm *localtime(const time_t *timep)
功能:将日历时间转换成本地时间,并保存在TM结构。


时间保存结构

struct tm {
int tm_sec;//秒
int tm_min;//分钟值
int tm_hour小时制
int tm_mday;//本月第几日
int tm_mon;;//本年第几月
int tm_year;//tm_year+1900=哪一年
int tm_wday;//本周第几日
int tm_yday;//本年第几日
int tm_isdst;//日光节约时间
}


时间显示

char *asctime(const struct tm *tm)
功能:将tm格式的时间转化为字符串,如:

 sat jul 30 08:43:03 2005


 char *ctime(const time_t *timep)
功能:将日历时间转化为本地时间的字符串形式


获取时间

int gettimeofday(struct timeval *tv,struct timezone *tz)
功能:获取从今日凌晨到现在的时间差,常用于计算时间耗时。


struct timeval{
int tv_sec;//秒数
int tv_usec;//微妙数

}

下面这个小程序就是计算程序的运行时间。

#include<sys/time.h>
#include<stdio.h>
#include<stdlib.h>
#include<math.h>

/*算法分析*/

void function()
{
	unsigned int i,j;
	double y;
	for(i=0;i<1000;i++)
		for (j=0;j<1000;j++)
			y++;
}

main()
{
	struct timeval tpstart, tpend;
	float timeuse;
	
	gettimeofday(&tpstart,NULL);//得到开始时间
	function();//运行function()
	gettimeofday(&tpend,NULL);//得到结束时间
/* 计算function的运行时间*/
	timeuse=1000000*(tpend.tv_sec-tpstart.tv_sec)+(tpend.tv_usec-tpstart.tv_usec);
	timeuse/=1000000;
	printf("used time:%f\n", timeuse);
	exit(0);
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章