问题

安装编译完 Boost 后,如果不设置 BOOST_ROOTBOOST_BUILD_PATH 则可能导致使用 bjam 时定位到 Boost 默认的路径 /usr/share/boost-build,而如果此目录下已有系统默认的 Boost 相关安装文件,就会导致 Boost 当前版本和默认安装版本不匹配的错误。

方案

直接修改 .bashrc,加入下述两句即可 (注意,我这里使用的路径是我默认的 boost 编译路径 /usr/local/boost_1_67_0,读者应该根据自己的路径更改)

export BOOST_ROOT=/usr/local/boost_1_67_0
export BOOST_BUILD_PATH=/usr/local/boost_1_67_0

======================================================

注意,以上是迂回的做法,正规的做法如下:

0.1) 安装之前,最好把链接 /usr/bin/python (默认指向 python2.7) 修改为指向 python3 ,安装完再调回去。以后主要使用 python3。 

0.2) 因为 python3 的头文件路径可能为 /usr/include/python3.6m,而 Boost 默认查找的路径为  -I"/usr/include/python3.6",所以需要在 /usr/include/ 下新建一个链接 /usr/include/python3.6,使其指向 /usr/include/python3.6m。

0.3) 对于服务器,要求稳定,可以选择 CentOS。对于个人应用环境,建议使用 Ubuntu,因为 CentOS 软件过于陈旧,编译最新的 BOOST,PyBind11,可能会有一些兼容性问题需要手动调节,比如上述的 0.2) 在 Ubuntu 18.04 下是没有的。

1) Boost 的编译

注:Boost 有些库需要编译成动态链接或静态库文件,才能使用,大多数库都只有头文件,头文件里的函数以模板,内联方式实现,直接包含即可。

如果直接将 Boost 解压缩到 /usr/local/boost_1_67_0,而且编译安装采用默认路径,即没有带设置参数 --prefix=xxx,则 Boost 默认将编译的库文件存放在 /usr/local/lib 下,而头文件存放在 /usr/local/include 下,这样在编译 Boost 相关程序时,如果需要链接库文件,则直接指向 /usr/local/lib 中相应的静态库或动态库即可,而需要的头文件则可以指向 /usr/local/include 或者可以指向原始的 Boost 包解压路径 /usr/local/boost_1_67_0 (也即 BOOST_ROOT)。

用到的编译安装命令如下,(注意,因为要安装在 /usr/local/ 下,所以安装时需要 sudo)

/usr/local/boost_1_67_0$ ./bootstrap.sh
/usr/local/boost_1_67_0$ sudo ./b2 install

2)Boost.Build 的编译

注:Boost.Build 是 Boost 官方工作人员,为了应对 Boost 在各种环境下的编译安装而开发的一套 Build 系统,可以完全独立于 Boost 库运行,支持 C/C++ 工程的 Build  和管理,功能类似于 cmake。

Boost.Build 随 Boost 库发行,也可以单独下载编译安装,此处以 Boost 库附带的 Boost.Build 安装为例,首先进入 /usr/local/boost_1_67_0/tools/build,然后运行命令如下,

/usr/local/boost_1_67_0/tools/build$ ./bootstrap.sh
/usr/local/boost_1_67_0/tools/build$ sudo ./b2 install --prefix=/usr/local/

这样,安装完后,可执行文件 b2 和 bjam (两个完全一样)将在 /usr/local/bin 下,而 Boost.Build 系统文件将在 /usr/local/share/boost-build/ 下。

注意:如果安装之前,系统已经有默认的 Boost 可执行文件 b2 或 bjam 在 /usr/local/bin 下,有默认的 Boost.Build 系统文件在 /usr/local/share/boost-build 下,先将它们删除,再安装当前的新版本即可。

=======================================================

安装完成之后,解决找不到动态链接库的问题

在 /etc/ld.so.conf.d/ 下创建文件 boost_lib.conf (文件名任意),添加 boost lib 路径 /usr/local/lib,然后执行如下命令即可,

$ sudo ldconfig

完。

Boost 和 Boost.Build 的设置的更多相关文章

  1. 【Boost】boost库中timer定时器 2

    博客转载自:http://blog.csdn.net/yockie/article/details/40386145 先跟着boost文档中asio章节的指南中的几个例子学习一下使用: 所有的Asio ...

  2. boost::thread boost库线程

    一.boost::thread的创建 1.线程创建方法一: boost::shared_ptr<boost::thread> writeThread_; boost::function0& ...

  3. 【Boost】boost库asio详解3——io_service作为work pool

    无论如何使用,都能感觉到使用boost.asio实现服务器,不仅是一件非常轻松的事,而且代码很漂亮,逻辑也相当清晰,这点上很不同于ACE.使用io_service作为处理工作的work pool,可以 ...

  4. 【Boost】boost库asio详解5——resolver与endpoint使用说明

    tcp::resolver一般和tcp::resolver::query结合用,通过query这个词顾名思义就知道它是用来查询socket的相应信息,一般而言我们关心socket的东东有address ...

  5. 初识boost之boost::share_ptr用法

    boost中提供了几种智能指针方法:scoped_ptr shared_ptr intrusive_ptr weak_ptr,而标准库中提供的智能指针为auto_ptr. 这其中,我最喜欢,使用最多的 ...

  6. boost信号量 boost::interprocess::interprocess_semaphore的用法

    使用方法首先给信号量初始化赋值,可以根据需要设定需要的值,之前在写项目的过程中用这个控制下载的线程个数. boost::interprocess::interprocess_semaphore m_s ...

  7. 【Boost】boost::tokenizer详解

    分类: [C++]--[Boost]2012-12-28 21:42 2343人阅读 评论(0) 收藏 举报   目录(?)[+]   tokenizer 库提供预定义好的四个分词对象, 其中char ...

  8. 【Boost】boost::string_algo详解2——find相关函数

    来自: https://blog.csdn.net/huang_xw/article/details/8276123 函数声明:   template<typename Range1T, typ ...

  9. 【C++】boost::shared_ptr boost::make_shared

    一.shared_ptr shared_ptr作为一个动态分配的对象,当最后一个指向其内容的指针销毁(destroyed)或重置(reset),其指向的内容会被销毁(deleted).不再需要显式调用 ...

随机推荐

  1. 《JavaScript高级程序设计》笔记:变量、作用域和内存问题(四)

    基本类型和引用类型的值 ECMAScript变量可能包含两种不同数据类型的值:基本类型值和引用类型值.基本类型值指的是简单的数据段,而引用类型的值指那些可能有多个值构成的对象. 动态的属性 var p ...

  2. BZOJ2746: [HEOI2012]旅行问题(AC自动机 LCA)

    Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 1188  Solved: 383[Submit][Status][Discuss] Descripti ...

  3. docker swarm 集群进入某节点容器失败的原因及解决方法

    今日在自己的docker swarm 测试环境中,想进入某个节点的容器去查看下,结果进入容器失败,并且报了如下错误信息: [root@worker1 ~]# docker exec -it 9a6f6 ...

  4. vue 构建项目 文件引入

    1.vue引用依赖文件.  举例:axios 先安装 axios.如果直接安装 vue-axios 会报错 npm install axios npm install --save axios vue ...

  5. 直接通过Binder的onTransact完成跨进程通信

    1.具体代码: 服务端实现: public class IPCService extends Service { private static final String DESCRIPTOR = &q ...

  6. (后端)swagger

    Swagger 文档提供了一个方法,使我们可以用指定的 JSON 或者 YAML 摘要来描述你的 API,包括了比如 names.order 等 API 信息. 你可以通过一个文本编辑器来编辑 Swa ...

  7. (后端)解决code唯一码(java)简便方法

    public String next() { long appBootTimes = systemVariableService.getAppBootTimes(); return Long.toSt ...

  8. html之css选择器学习

    相关内容: 什么是css选择器 标签选择器 类选择器 id选择器 并集选择器(分组选择器) 交集选择器 后代选择器 子标签选择器 属性选择器 相邻兄弟选择器 伪类选择器 伪元素选择器(伪对象选择器) ...

  9. html之CSS样式学习笔记

    本文内容: 字体样式 文本样式 背景样式 尺寸样式 盒子模型 边框样式 边距样式 浮动布局 定位布局 [CSS3]伸缩布局 标签显示方式 列表样式 [CSS3]过渡样式 [CSS3]变换样式之2D变形 ...

  10. 【软件需求工程与建模 - 小组项目】第6周 - 成果展示3 - 软件设计规格说明书V4.1

    成果展示3 - 软件设计规格说明书V4.1