boost::tr1与std::tr1冲突了怎么办?

转:http://www.cnblogs.com/rocketfan/archive/2010/12/29/1920943.html

最近用boost::math库,发现会和我以前的程序冲突。比如我的程序如果用到

#include 等等std::tr1名字域下的东西。。。

google了下,原因是boost::tr1设计初衷是为了在你的系统没有std::tr1标准库实现的情况下让你仍然可以在程序中使用std::tr1::unordered_map, std::tr1::tuple等东东,当然了这是一个work around,也就是你其实还是用的boost::tuple等等

只是你的代码写的时候可以写std::tr1::tuple。

比如boost的math库的一个分布函数的实现

/usr/include/boost/math/special_functions/detail/igamma_inverse.hpp

在该文件第13行

#include

然后下面它就用到了tuple使用如下

std::tr1::tupleoperator() (constT& x) const  //其实呢还是用的boost::下面的tuple

看下/usr/include/boost/tr1/tuple.hpp

namespacestd{namespacetr1{using::boost::fusion::tuple;// [6.1.3.2] Tuple creation functionsusing::boost::fusion::ignore;using::boost::fusion::make_tuple;using::boost::fusion::tie;using::boost::fusion::get;// [6.1.3.3] Tuple helper classesusing::boost::fusion::tuple_size;using::boost::fusion::tuple_element; }}

这就是work around的方法。

现在问题来了,我的GCC已经有std::tr1的实现了,比如 ,那么着就会带来命名冲突了,比如同时又两个tuple定义了。。。。boost::fusion::tuple和原生的std::tr1::tuple。

见boost::tr1的文档

实现

如果 Boost.TR1被配置为使用你的标准库中的原生 TR1 实现,则它不需要做多少事情:它只是包含适当的头文件就行了。

如果 Boost.TR1 使用了某个组件的 Boost 实现,则它需要包含适当的 Boost 头文件并使用声明将所需的名字导入到namespace std::tr1中。注意,只有作为标准部分的声明会被导入:本实现有意非常严格地没有将所有 Boost-特有的扩展引入到namespace std::tr1,这是为了能够捕获用户代码中的任何可移植性错误。如果你真的需要使用 Boost-特有的扩展,则你应当直接包含 Boost 头文件,则改用namespace boost::中的声明。注意,本实现的风格并不是完全符合标准的,它不能将用户自定义的 TR1 组件的模板特化增加到namespace std::tr1中。还有一到两个 Boost 库尚未完全符合标准,任何与标准不符的地方都已在"TR1 的分类"一节中说明。不过幸好,这些不符合标准的行为在实际中极少会用到。

如果你使用标准的头文件包含(在boost/tr1/tr1中),则这些头文件名有时可能与现有的标准库头文件冲突(例如shared_ptr已增加到现有的标准库头文件中而不是它自己的头文件)。这些头文件可以用以下两种方法之一前转到现有的标准库头文件:对于 gcc,使用#include_next, 而对于其它编译器则使用宏BOOST_TR1_STD_HEADER(header)(在boost/tr1/detail/config.hpp中定义),它将扩展为#include <../include/header>. 对于大多数编译器,这样就可以直接使用,但是这意味着这些头文件不能被放在名为"include"且已在你的编译器搜索路径中的目录下。

怎么解决冲突问题呢,还是没有完全弄明白,不过解决办法还是google到了。。 OK 解决了就好。。 以后再说。

按理说按照boost/tr1/tuple.hpp  中所写的

#ifdef BOOST_HAS_TR1_TUPLE#  ifdef BOOST_HAS_INCLUDE_NEXT#    include_next BOOST_TR1_HEADER(tuple)#else#    include #    include BOOST_TR1_STD_HEADER(BOOST_TR1_PATH(tuple))#  endif

我应该加一个 #define BOOST_HAS_tR1_TUPLE 就能解决问题 因为 BOOST_TR1_HEADER(tuple)  会被转换为#include

但是实验不成功。。。。

usr/include/boost/tr1/tuple.hpp:13:43: error: no include path in which to search for tr1/tuple  //WHY 知道为什么的帮忙告诉我下,谢谢~

//估计可能是incude_next的原因? 没太仔细看include_next作用TODO

最后google到的解决方案是

#defineBOOST_HAS_TR1_TUPLE 1#include #undefBOOST_HAS_INCLUDE_NEXT  //似乎是需要屏蔽掉 incude_next

好吧 暂时和平了 费了我好多时间 希望后面谁也碰到这种情况的问题能节省下时间:)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容