将天数添加到日期 C++
Adding Days to a Date c++
我正在尝试为日期添加一定天数。我看过 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.
您没有检查 mktime(&expire_time);
的 return 值。根据 documentation 它 returns -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;
}
然后在调用时检查函数的 return 值。
然后,现在让我们来看看为什么 mktime
说它无法转换您的日期。
当您使用 01152016
作为输入日期时,日期中的年份为 2016
。但是,当您将字符串转换为 int 时,您会向其添加额外的 1900
(year1 = atoi(start_date.Mid(4)) + 1900;
),使日期等于 3916
。显然,这比 mktime
可以处理的未来太远了(我的猜测是,它不能在 time_t
的大小限制内代表你的日期)。
请注意,即使您在函数中减去年份 1900
,到 mktime
年份仍然等于 3916
,因为 tm.tm_year 定义为 "years since 1900",所以1900年之后还有2016年,还是等于3916.
我正在尝试为日期添加一定天数。我看过 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.
您没有检查 mktime(&expire_time);
的 return 值。根据 documentation 它 returns -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;
}
然后在调用时检查函数的 return 值。
然后,现在让我们来看看为什么 mktime
说它无法转换您的日期。
当您使用 01152016
作为输入日期时,日期中的年份为 2016
。但是,当您将字符串转换为 int 时,您会向其添加额外的 1900
(year1 = atoi(start_date.Mid(4)) + 1900;
),使日期等于 3916
。显然,这比 mktime
可以处理的未来太远了(我的猜测是,它不能在 time_t
的大小限制内代表你的日期)。
请注意,即使您在函数中减去年份 1900
,到 mktime
年份仍然等于 3916
,因为 tm.tm_year 定义为 "years since 1900",所以1900年之后还有2016年,还是等于3916.