测试小组提交在ClearQuest上的一个Defect引起了我的注意,当一个逻辑中输入日期为1940年以前的任何一个值时,会产生异常,程序逻辑不正常,直觉告诉我,这有可能是其中用到时间比较时出了错,果不其然,在经过仔细定位后发现一段程序:
而跟踪到这里时发现,计算出的这个diff居然是负值!
仔细查阅文档,发现我的boost date_time库在编译时选择了time_duration的ticks数据类型为__int64,此时发生了数据溢出:)
65*365*24*60*60*1000000000
boost::posix_time::time_duration diff = util::ptime_now() - util::oletime_to_boosttime(dateOfBirth);
if( diff.is_negative() || diff > boost::posix_time::hours(200*365*24) )
return E_INVALIDARG;
}
改成用DATE_DURATION来计算就没有问题了
boost::gregorian::date_duration diff = boost::gregorian::day_clock::local_day()- util::oledate_to_boostdate(dateOfBirth);
if( diff.is_negative() || diff > boost::gregorian::date_duration(200*365) )
return E_INVALIDARG;
}