使用-std = c 0x增加1.53本地日期时间编译器错误

使用g版本4.7.2,如果我尝试编译以下内容
#include <boost/date_time/local_time/local_time.hpp> 

class Bar
{
public:

Bar() { tz_db_.load_from_file("/home/date_time_zonespec.csv"); }

private:
    boost::local_time::tz_database tz_db_;
};

int main()
{
    return 0;
}

使用-std = c 0x我收到以下错误.

In file included from /usr/local/include/boost/date_time/local_time/local_time_types.hpp:18:0,from /usr/local/include/boost/date_time/local_time/local_time.hpp:13,from test.h:4,from test.cpp:1: /usr/local/include/boost/date_time/local_time/custom_time_zone.hpp: In instantiation of ‘bool boost::local_time::custom_time_zone_base<CharT>::has_dst() const [with CharT = char]’: test.cpp:11:1:   required from here /usr/local/include/boost/date_time/local_time/custom_time_zone.hpp:67:30: error: cannot convert ‘const boost::shared_ptr<boost::date_time::dst_day_calc_rule<boost::gregorian::date>
>’ to ‘bool’ in return

如果我不使用c 0x选项,一切都很好.
谁能告诉我这里发生了什么?

解决方法

当你为C 11构建时,boost :: shared_ptr :: operator bool()被声明为显式.这通常是一件好事,但遗憾的是它会破坏依赖于隐式转换的代码,例如此函数(这是导致错误的原因):
virtual bool has_dst() const
{
  return (dst_calc_rules_); //if calc_rule is set the tz has dst
}

其中dst_calc_rules_是shared_ptr.

直到Boost的某个人开始修复它,你可以做两件事:

>破解该函数返回bool(dst_calc_rules_);>定义BOOST_NO_CXX11_EXPLICIT_CONVERSION_OPERATORS以允许隐式转换.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...