测试小组提交在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;
}
测试小组在ClearQuest上提交的Defect显示,程序在输入1940年以前日期时逻辑异常。经定位,发现是boost date_time库编译时time_duration的ticks数据类型为__int64导致数据溢出。最终将计算方式改成用DATE_DURATION,问题得以解决。
1697

被折叠的 条评论
为什么被折叠?



