zoukankan      html  css  js  c++  java
  • linux下安装boost

    (一). 在Terminal中分别执行以下3步安装boost:

    1. 下载后进入压缩包所在目录解压: sudo tar -zxvf boost_1_52_0.tar.gz

    2. 进入./boost_1_52_0,运行: sudo ./bootstrap.sh --prefix=/usr

      /usr 可替换为任意路径  (事前运行./bootstrap.sh --help 看下参数说明)

    3. sudo ./b2 install

    整个安装用时比Windows下安装短很多。将在目标安装文件夹下的/lib、/include下产生库文件。

    (二). 编译C++项目文件时,要Link上对应所需的库,不然会产生诸如:

    undefined reference to `boost::system::generic_category()'
    undefined reference to `boost::thread::start_thread()'

    这样的信息。方法是修改Makefile文件。

    打开Makefile找到规则

      $(LINK) $(LFLAGS) -o $(TARGET) $(OBJECTS) $(OBJCOMP) $(LIBS)

    修改为:

      $(LINK) $(LFLAGS) -o $(TARGET) $(OBJECTS) $(OBJCOMP) $(LIBS) -lboost_system -lboost_thread

    注意Makefile的格式/tab与空格是有定义区别的,而如果用QTCreator打开Makefile,保存时会以数个空格替换掉/tab,这将导致后续make不能执行,所以需要用比如Vim这样的编辑器打开修改。

    (三). 编译成功后运行执行档,如果出现

    error while loading shared libraries: libboost_system.so.1.52.0: cannot open shared object file: No such file or directory

    是因为系统在当前注册的搜索路径{PATH}中找不到所需的共享库。PATH是Enviroment Variable:

    echo "$HOME"

    echo "$PATH"

    输出环境变量的值;

    修改或设置则可以用export指令:

    export PATH=${PATH}:/usr/local/lib:/usr/local/include

  • 相关阅读:
    innodb force recovery
    date 获取昨天日期
    Mysql slave 状态之Seconds_Behind_Master
    shell编程——if语句 if -z -n -f -eq -ne -lt
    shell判断条件是否存在
    linux shell if 参数
    MYSQL使用二进制日志来恢复数据
    linux下nagios的安装与部署
    mysql slave 错误解决
    LODS LODSB LODSW LODSD 例子【载入串指令】
  • 原文地址:https://www.cnblogs.com/edgarli/p/boost.html
Copyright © 2011-2022 走看看