我正在尝试为某个日期添加一定的天数。我查看了Arithmetics on calendar dates in C or C++ (add N days to given date)等示例,但我仍然遇到了这个问题。
如果num_of_days是一个很大的数字,那就说100,开始的一天是expire_time.tm_mday = 10.最后一天是110.所以当我做mktime(& expire_time);它不会将这一天转换为有效时间; expire_time.tm_mday仍然等于110.我希望它增加3个月,并且是1-31之间的一天。这是为什么?
void add_num_of_days(int* month, int* day, int* year, int num_of_days)
{
struct tm expire_time = {};
int date_to_days;
expire_time.tm_year = *year - 1900;
expire_time.tm_mon = *month - 1;
expire_time.tm_mday = *day;
//expire_time.tm_mday = 15;
//num_of_days = 40;
expire_time.tm_mday += num_of_days;
mktime(&expire_time);
//expire_time.tm_mday = 55! (NOT WHAT I WANT).
*day = expire_time.tm_mday;
*month = expire_time.tm_mon + 1;
*year = expire_time.tm_year + 1900;
}
主叫代码:
month1 = atoi(start_date.Mid(0, 2)) + 1;
day1 = atoi(start_date.Mid(2, 2));
year1 = atoi(start_date.Mid(4)) + 1900;
//Add the number of days the license
//period is for to the start date.
add_num_of_days(&month1, &day1, &year1, atoi(num_of_days));
开始日期:
//First 32 bits is for the starting date.
CString start_date = get_start_date(byte_array.Mid(0, 32));
//Example start_date would be 01152016 for Jan 15th 2016.
答案 0 :(得分:1)
您没有检查mktime(&expire_time);
的返回值。根据{{3}},如果无法表示日历时间,它将返回-1
,因此在这种情况下,您的输入参数将保持不变。
为避免此类问题,您可以将程序更改为:
bool add_num_of_days(int* month, int* day, int* year, int num_of_days)
{
struct tm expire_time = {};
int date_to_days;
expire_time.tm_year = *year - 1900;
expire_time.tm_mon = *month - 1;
expire_time.tm_mday = *day;
expire_time.tm_mday += num_of_days;
if (-1 == mktime(&expire_time))
{
return false;
}
*day = expire_time.tm_mday;
*month = expire_time.tm_mon + 1;
*year = expire_time.tm_year + 1900;
return true;
}
然后在调用时检查函数的返回值。
而且,现在让我们了解为什么 mktime
说它无法转换您的约会。
当您使用01152016
作为输入日期时,日期中的年份为2016
。但是,当您从字符串转换为int时,您需要向其添加额外的1900
(year1 = atoi(start_date.Mid(4)) + 1900;
),使日期等于3916
。显然,未来mktime
可以处理得太远(我的猜测是,它不能代表time_t
的大小范围内的日期。
请注意,即使您在函数中减去1900
年,mktime
年仍然等于3916
,因为documentation定义为&#34 ;自1900年以来的岁月",所以当你在1900年之后的2016年,它仍然等于3916。