Boost库编译

虽然网上已经有了现成的编译流程,但是,在自己编译的时候,还是遇到一些问题。

1、开始我是通过SVN Check源码下来编译,结果Check了几个小时,都没有完全的Check下来,最后还是老实下载压缩包boost_1_46_1.tar.gz

2、解压,编译,照到网上的搞

3、编译完成后,Boost库会在/usr/local/include下生成boost目录,里面是Boost库的头文件,并且直接把生成的库文件直接拷贝到了/usr/local/lib

4、在写测试程序时,引入Boost库的头文件时,可能会出错,大概原因是因为Boost 库的头文件没有找到,通过环境就是或者其它方式设置Boost库的头文件路径(我现在只晓得设置环境就是这一种方式,恼火),再编译一下,应该会成功拉。

 

扩展了解:

一、ldconfig:当引入新的库,并且不是在系统的搜索目录中时,可以修改/etc/ld.so.conf,添加新库所在目录。

下面这段话是引用:http://apps.hi.baidu.com/share/detail/14698080

ldconfig几个需要注意的地方!
1. 往/lib和/usr/lib里面加东西,是不用修改/etc/ld.so.conf的,但是完了之后要调一下ldconfig,不然这个library会找不到

2. 想往上面两个目录以外加东西的时候,一定要修改/etc/ld.so.conf,然后再调用ldconfig,不然也会找不到
比 如安装了一个mysql到/usr/local/mysql,mysql有一大堆library在/usr/local/mysql/lib下面,这时就 需要在/etc/ld.so.conf下面加一行/usr/local/mysql/lib,保存过后ldconfig一下,新的library才能在程 序运行时被找到。

3. 如果想在这两个目录以外放lib,但是又不想在/etc/ld.so.conf中加东西(或者是没有权限加东西)。那也可以,就是export一个全局变 量LD_LIBRARY_PATH,然后运行程序的时候就会去这个目录中找library。一般来讲这只是一种临时的解决方案,在没有权限或临时需要的时 候使用。

4. ldconfig做的这些东西都与运行程序时有关,跟编译时一点关系都没有。编译的时候还是该加-L就得加,不要混淆了。

5. 总之,就是不管做了什么关于library的变动后,最好都ldconfig一下,不然会出现一些意想不到的结果。不会花太多的时间,但是会省很多的事。

二、设置环境变量:export XXX="xxx"
        查看环境就是:echo $XXX
       注意:如果export是在当前终端下执行的,则些环境就是只是临时的,且只在当前终端有效。

 

三、随带了解了一下编译选项:

          g++ re.cpp -I$BOOST_ROOT -lboost_regex -o re

        -l:大写的i,是用来指定所要引用的头文件所在目录,在编译时,编译器会优先在你指定的目录下面去搜索头文件

        -l:小写的L,是用来指定所要连接的库文件

        -L:是用来指定所要连接的库文件所在的目录

 

 

现在看来,在LINUX下面写程序,对我这种习惯于Windows下开发的菜鸟来说,确实用起恼火。编译个库也要花几个小时,还不一定成功!!

### 解决Boost编译时遇到的问题 #### 1. 配置环境变量 确保已正确设置系统的环境变量,特别是 `PATH` 变量应包含 Visual Studio 的命令行工具路径以及 Boost 安装目录。这有助于避免因找不到必要的编译工具而导致的错误[^1]。 #### 2. 使用适当版本的Visual Studio 不同版本的 Boost 可能与特定版本的 Visual Studio 更兼容。例如,在 Windows 上使用较旧版本如 VS2015 来编译 Boost 1.63 或更高版本时,需确认所使用的 Visual Studio 版本能够支持目标 Boost 版本的要求[^3]。 #### 3. 自定义编译脚本调整 当通过批处理文件(`.bat` 文件)来启动编译过程时,务必检查这些脚本内的参数设定是否匹配当前开发环境的需求。对于某些特定平台或架构的选择(如 32 位 vs 64 位),应当仔细核对并作出相应修改以适应本地条件。 #### 4. 下载源码自行编译而非依赖预构建二进制包 尽管存在许多预先编译好的 Boost 可供下载,但由于不同的编译选项和配置可能导致不一致的行为,因此建议尽可能从官方渠道获取最新版源代码,并按照文档指导完成自定义化编译流程。这样做不仅可以获得更好的性能优化效果,还能有效规避由于第三方提供者采用的不同编译器或其他因素引起的潜在冲突问题[^4]。 #### 5. 查阅日志文件排查具体原因 如果仍然无法成功编译,则可以尝试阅读由 bjam 工具生成的日志文件 (`bootstrap.log`) 中的信息,从中寻找有关失败的具体线索。通常情况下,这类日志会记录下详细的执行步骤及其结果,从而帮助定位实际存在的技术难题所在之处。 ```bash # 进入到解压后的Boost根目录 cd path\to\boost_root_directory # 初始化bjam构建系统(适用于Windows) .\bootstrap.bat # 开始编译指定地址模型下的静态链接 b2 address-model=64 link=static threading=multi variant=release --build-type=complete stage ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值