CSDN博客

img timcai

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

发表于2004/7/1 17:39:00  1829人阅读

测试小组提交在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;
   }


0 0

相关博文

我的热门文章

img
取 消
img