zoukankan      html  css  js  c++  java
  • BOOST的AUTO link机制以及配置

    我们在使用BOOST的时候,如果需要链接一些库,是不用我们手动去链接的,归根结底还是boostauto_link这个机制,在boost下的auto_link.hpp这个文件夹里面,基本可以看出要根据什么宏定义去控制boost去链接什么库,比如lib开头的库编译出来的lib库,如果没有lib开头的,则是动态库,安装到客户机上的时候,我们需要带上对应的dll

     

    //
    // select linkage opt:
    //
    #if (defined(_DLL) || defined(_RTLDLL)) && defined(BOOST_DYN_LINK)
    #  define BOOST_LIB_PREFIX
    #elif defined(BOOST_DYN_LINK)
    #  error "Mixing a dll boost library with a static runtime is a really bad idea..."
    #else
    #  define BOOST_LIB_PREFIX "lib"
    #endif

    从这里我们可以看到只要不定义_DLL或者BOOST_DYN_LINK,那么boost就会自动去选择静态库

    不过这里有一个比较蛋疼的地方,因为只要你include了一个boost库的头文件后,比如python,那么boost就会去自动触发链接,具体看如下代码

    #ifdef BOOST_AUTO_LINK_TAGGED
    #  pragma comment(lib, BOOST_LIB_PREFIX BOOST_STRINGIZE(BOOST_LIB_NAME) BOOST_LIB_THREAD_OPT BOOST_LIB_RT_OPT ".lib")
    #  ifdef BOOST_LIB_DIAGNOSTIC
    #     pragma message ("Linking to lib file: " BOOST_LIB_PREFIX BOOST_STRINGIZE(BOOST_LIB_NAME) BOOST_LIB_THREAD_OPT BOOST_LIB_RT_OPT ".lib")
    #  endif
    #elif defined(BOOST_AUTO_LINK_NOMANGLE)
    #  pragma comment(lib, BOOST_STRINGIZE(BOOST_LIB_NAME) ".lib")
    #  ifdef BOOST_LIB_DIAGNOSTIC
    #     pragma message ("Linking to lib file: " BOOST_STRINGIZE(BOOST_LIB_NAME) ".lib")
    #  endif
    #else
    
    #  pragma comment(lib, BOOST_LIB_PREFIX BOOST_STRINGIZE(BOOST_LIB_NAME) "-" BOOST_LIB_TOOLSET BOOST_LIB_THREAD_OPT BOOST_LIB_RT_OPT "-" BOOST_LIB_VERSION ".lib")
    #  ifdef BOOST_LIB_DIAGNOSTIC
    #     pragma message ("Linking to lib file: " BOOST_LIB_PREFIX BOOST_STRINGIZE(BOOST_LIB_NAME) "-" BOOST_LIB_TOOLSET BOOST_LIB_THREAD_OPT BOOST_LIB_RT_OPT "-" BOOST_LIB_VERSION ".lib")
    #  endif
    #endif

     所以开发的时候我们经常会遇见这种情况,命名一个项目已经链接了lib python库,但是他却还是去链接pythondll库,这个是因为你在一个项目中指定要链接pythonlib库,而因为C++include的机制,只要你在另外一个项目递归include的文件里面有包含python的头文件,那么 就会触发这个自动链接机制,但是却没有在另外一个项目也指定链接静态库,就会让另外一个项目跑去链接DLL,所以我们需要定义这两个宏定义

    BOOST_PYTHON_STATIC_MODULE

    BOOST_PYTHON_STATIC_LIB

    在大部分的库目录下,都会有一个config.hpp,这里就是负责配置单个库的一些宏定义,如果需要知道哪个库有哪些配置,打开这个文件看一下就可以了

  • 相关阅读:
    Linux Shell编程入门
    vim 文件在linux不换行,只显示^M解决办法
    服务器高性能程序 磁盘I/O篇
    车牌识别_转自别人的博客
    ubuntu网络简单设置
    C++设计模式(转载)
    结构算法之道
    C++设计模式工厂方法
    二叉树的深度优先遍历、广度优先遍历和非递归遍历
    iptables
  • 原文地址:https://www.cnblogs.com/linyilong3/p/4171503.html
Copyright © 2011-2022 走看看