問題?用mktime函數時,月份未減一會出現什麼情況?
time_t mktime(struct tm *)
其中的tm結構體定義如下:
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()爲負。*/ };
我們只要給出年月日時分秒,然後用mktime()就可以,獲取的星期存在tm_wday中
https://blog.csdn.net/YuZhiHui_No1/article/details/42888237
mktime爲什麼那麼慢:https://blog.csdn.net/test201105/article/details/49815103
測試程序如下:如果月份未減一
#include "time.h"
#include "stdio.h"
#include "stdlib.h"
int main(void) {
struct tm t1;
struct tm t2;
struct tm t3;
time_t auqian; //2018年8月31日23點58分45秒
time_t auzhong; //2018年3月31日0點0分0秒
time_t hou; //2018年5月31日點1分45秒
t1.tm_year=2018-1900;
t1.tm_mon=8;
t1.tm_mday=31;
t1.tm_hour=23;
t1.tm_min=58;
t1.tm_sec=45;
t1.tm_isdst=0;
t2.tm_year=2018-1900;
t2.tm_mon=3;
t2.tm_mday=31;
t2.tm_hour=0;
t2.tm_min=0;
t2.tm_sec=0;
t2.tm_isdst=0;
t3.tm_year=2018-1900;
t3.tm_mon=5;
t3.tm_mday=31;
t3.tm_hour=0;
t3.tm_min=1;
t3.tm_sec=45;
t3.tm_isdst=0;
auqian = mktime(&t1);
printf("%d ",auqian);
printf("%s",ctime(&auqian));
auzhong = mktime(&t2);
printf("%d ",auzhong);
printf("%s",ctime(&auzhong));
hou = mktime(&t3);
printf("%d ",hou);
printf("%s",ctime(&hou));
getchar();
return 0;
}
測試結果如下:很明顯8月31日 變爲10月1日 3月31日變爲5月1日 5月31日變爲6月1日
原因:通過測試發現月份不減1,每逢1,3,5,8,10月他用mktime算出的時間:比如輸入3月31日就會變爲5月1號
第一個原因是:由於時間結構體裏的月份存儲範圍爲0~11,所以不減一會被解析爲4月,而四月又是小月,他沒有第31天;由於mktime函數本身的強大,他會直接把多出的一天算到下個月的第一天,也就是變成了五月1號。
所以在跨月的時候是跨月之前的時間變大了,變大了將近一天時間。
這如果用來上傳數據,計算前後時間戳就爲負值,很容易出現不容易發現的問題。