我正在使用VS2010,这段代码被编译成ANSI项目
int C90Clockadapter_GetCW_ISO8601(const C90Clockadapter * clockadapter, int * calendarweek)
{
int e = 0;
struct tm tm;
char timebuf[64];
memset( &tm, 0, sizeof( tm ) );
tm.tm_mday = clockadapter->mDay;
tm.tm_mon = clockadapter->mMonth;
tm.tm_year = clockadapter->mYear;
mktime(&tm);
if (0 != strftime(timebuf,sizeof(timebuf),"%W", &tm) ) //i know %W is not ISO8601
{
*calendarweek = atoi(timebuf);
}
else
{
e |= 1;
}
return e;
}不知何故,mktime(&tm)不会改变tm的状态。这种行为完全不符合我的期望。
我编写了一些具有自我解释输出的单元测试:
4.1.1971 - expected CW 1 but was CW 0
31.12.1992 - expected CW 53 but was CW 0我的代码有什么问题吗?还是windows或vs2010和ansi-c中有一些我缺少的特性?
发布于 2014-02-10 09:15:17
时间格式无效。mktime返回-1,这是未处理的。
这个片段展示了如何正确地填充struct tm。
tm.tm_mday = clockadapter->mDay;
tm.tm_mon = clockadapter->mMonth - 1;
tm.tm_year = clockadapter->mYear - 1900;发布于 2014-02-05 20:39:06
引用表示它不一定会修改timeptr参数。您应该使用返回值。请参阅http://www.cplusplus.com/reference/ctime/mktime/
time_t mktime (struct tm * timeptr);https://stackoverflow.com/questions/21587909
复制相似问题