使用Boost与c++ 14编译器
Using Boost with C++14 compiler
当我用c++ 11支持(使用-std=c++11
标志)编译我的代码并使用非头文件仅Boost库时,我需要用-std=c++11
编译Boost。这是因为当启用c++ 11时,Boost在头文件中有一些接口差异,并且对于不同的c++标准,一些函数签名是不同的。
我的问题是,对于c++ 14(使用g++ 4.9,带有' -std=c++1y标志)是否也是如此,或者对于用c++ 14编译的程序使用c++ 11编译的Boost是否安全?
这是一个非常宽泛的问题,很难明确地回答,因为
- Boost是一个图书馆联盟,其中许多都有十多年的历史了
- 有相当多的向后兼容性,原则上可以发生,有些由编译器检测到,有些只能由单元测试
- 许多Boost库实际上是c++ 11/14特性(包括库和编译器功能)的c++ 98实现,因此您不需要在c++ 11/14项目中使用它。Boost本身也在争论库应该以什么速度更新到c++ 11/14,是否应该编写充分利用c++ 11/14的V2版本的库,甚至新的c++ 11/14库是否应该提供向后的c++ 98兼容性。
您可能需要仔细阅读编译器错误(如果有的话),并将它们与下面列出的破坏性更改列表进行比较。此外,我建议使用Boost测试工具来查找适用于您系统的可疑编译器/库组合。
这里有一些相关的问题:
- c++ 11中引入了哪些突破性的变化?
- c++ 14中引入的哪些变化可能会破坏用c++ 11编写的程序?
- 与c++ 11相关的boost特性
- boost使用c++11有多好?
相关文章:
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么所有C++编译器都会崩溃或挂起此代码
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 我收到同义重复编译器错误。我应该如何修复"类型"X"的参数与类型"X"的参数不兼容?
- 为什么C++编译器没有检测到正确声明的类?