您的位置:首页 > 其它

一个用到Boost中time_duration类而产生的bug

2004-07-01 17:39 513 查看
测试小组提交在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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: