如何实现每一天对一个变量累加1...
貌似没找到一个函数能直接返回日期...有的话就好了
程序代码:
1 函数原型:char *ctime(const time_t *time); 功能说明:将time_t类型日期和时间转换为字符串。 头文件: 参数说明:语法:ctime[必要参数] 必要参数的具体说明如下: time:指向time_t结构的指针。 返回值:返回由tm结构中的日期和时间转换成的字符串的地址,该字符串的形式定义如下: DDD MMM dd hh:mm:ss YYYY 各字符的意义: DDD 一星期的某一天,如Mon MMM 月份,如Jan dd 月中一天(1,2,……,31) hh 小时(1,2,……,24) mm 分钟(1,2,……,59) ss 秒数(1,2,……,59) YYYY 年 2 函数原型:char *asctime(const struct tm *tblock); 功能说明: 将tm结构类型时间日期转换为ASCII码。 头文件: 参数说明:语法:asctime[必要参数] 必要参数的具体说明如下: tblock:待转换的时间指针,tblock为一tm结构型指针。 返回值:返回由tm结构中的日期和时间转换成的字符串的地址,该字符串的形式定义如下: DDD MMM dd hh:mm:ss YYYY 各字符的意义: DDD 一星期的某一天,如Mon MMM 月份,如Jan dd 月中一天(1,2,……,31) hh 小时(1,2,……,24) mm 分钟(1,2,……,59) ss 秒数(1,2,……,59) YYYY 年 3 使用time函数返回的是一个long值,该值对用户的意义不大,一般不能根据其值确定具体的年、月、日等数据。gmtime函数可以方便的对time_t类型数据进行转换,将其转换为tm结构的数据方便数据阅读。 gmtime函数的原型如下: struct tm *gmtime(time_t *timep); localtime函数的原型如下: struct tm *localtime(time_t *timep); 将参数timep所指的time_t类型信息转换成实际所使用的时间日期表示方法,将结果返回到结构tm结构类型的变量。 gmtime函数用来存放实际日期时间的结构变量是静态分配的,每次调用gmtime函数都将重写该结构变量。如果希望保存结构变量中的内容,必须将其复制到tm结构的另一个变量中。 gmtime函数与localtime函数的区别: gmtime函数返回的时间日期未经时区转换,是UTC时间(又称为世界时间,即格林尼治时间)。 localtime函数返回当前时区的时间 4 可以通过time()函数来获得计算机系统当前的日历时间(Calendar Time),处理日期时间的函数都是以本函数的返回值为基础进行运算。其原型为: time_t time(time_t * t); 如果你已经声明了参数t,你可以从参数t返回现在的日历时间,同时也可以通过返回值返回现在的日历时间,即从一个时间点(例如:1970年1月1日0时0分0秒)到现在此时的秒数。如果参数为空(NULL),函数将只通过返回值返回现在的日历时间 5 #ifndef __TIME_T #define __TIME_T /* 避免重复定义 time_t */ typedef long time_t; /* 时间值time_t 为长整型的别名*/ #endif 既然time_t实际上是长整型,到未来的某一天,从一个时间点(一般是1970年1月1日0时0分0秒)到那时的秒数(即日历时间)超出了长整形所能表示的数的范围怎么办?对time_t数据类型的值来说,它所表示的时间不能晚于2038年1月18日19时14分07秒。为了能够表示更久远的时间,一些编译器厂商引入了64位甚至更长的整形数来保存日历时间。比如微软在Visual C++中采用了__time64_t数据类型来保存日历时间,并通过_time64()函数来获得日历时间(而不是通过使用32位字的time()函数),这样就可以通过该数据类型保存3001年1月1日0时0分0秒(不包括该时间点)之前的时间。 在time.h头文件中,我们还可以看到一些函数,它们都是以time_t为参数类型或返回值类型的函数: double difftime(time_t time1, time_t time0); time_t mktime(struct tm * timeptr); time_t time(time_t * timer); char * asctime(const struct tm * timeptr); char * ctime(const time_t *timer); 此外,time.h还提供了两种不同的函数将日历时间(一个用time_t表示的整数)转换为我们平时看到的把年月日时分秒分开显示的时间格式tm: struct tm * gmtime(const time_t *timer); struct tm * localtime(const time_t * timer); 通过查阅MSDN,我们可以知道Microsoft C/C++ 7.0中时间点的值(time_t对象的值)是从1899年12月31日0时0分0秒到该时间点所经过的秒数,而其它各种版本的Microsoft C/C++和所有不同版本的Visual C++都是计算的从1970年1月1日0时0分0秒到该时间点所经过的秒数。 #ifndef _TM_DEFINED struct tm { int tm_sec; /* 秒 - 取值区间为[0,59] */ int tm_min; /* 分 - 取值区间为[0,59] */ int tm_hour; /* 时 - 取值区间为[0,23] */ int tm_mday; /* 一个月中的日期 - 取值区间为[1,31] */ int tm_mon; /* 月份(从一月开始,0代表一月)- 取值区间为[0,11] */ int tm_year; /* 年份,其值等于实际年份减去1900 */ int tm_wday; /* 星期–取值区间为[0,6],其中0代表星期天,1代表星期一,以此类推 */ int tm_yday; /* 从每年的1月1日开始的天数 – 取值区间为[0,365],其中0代表1月1日,1代表1月2日,以此类推 */ int tm_isdst; /*夏令时标识符,实行夏令时的时候,tm_isdst为正。不实行夏令时的进候,tm_isdst为0;不了解情况时,tm_isdst()为负。*/ }; #define _TM_DEFINED /* 避免重复定义 tm */ #endif ANSI C标准称使用tm结构的这种时间表示为分解时间(broken-down time)。 包含文件: 把tm指针转换为time_t: time_t mktime(struct tm *timeptr);我的一点笔记,不知道是不是对楼主有用