想要静态编译,CMakeList添加如下选项
set(CMAKE_EXE_LINKER_FLAGS "-static")
更多编译技巧:http://blog.csdn.net/mr_chenping/article/details/23823825
表 1. 三种标准库链接方式的选项及区别
标准库连接方式示例连接选项优点缺点全静态-static
-pthread -lrt -ldl不会发生应用程序在 不同 Linux 版本下的标准库不兼容问题。生成的文件比较大,应用程序功能受限(不能调用动态库等)全动态-pthread
-lrt -ldl生成文件是三者中最小的比较容易发生应用程序在
不同 Linux 版本下标准库依赖不兼容问题。半静态
(libgcc,libstdc++)-static-libgcc -L. -pthread -lrt -ldl灵活度大,能够针对不同的标准库采取不同的链接策略,从而避免不兼容问题发生。结合了全静态与全动态两种链接方式的优点。比较难识别哪些库容易发生不兼容问题,目前只有依靠经验积累。某些功能会因选择的标准库版本而丧失。
样例:
cmake_minimum_required(VERSION 2.8)
#set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Wall")
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -Wall -O2")
project( labeling )
set(CMAKE_FIND_LIBRARY_SUFFIXES ".a")
add_library(OpenCV STATIC IMPORTED)
add_library(CGAL STATIC IMPORTED COMPONENTS Core)
add_library(GMP STATIC IMPORTED)
find_package(OpenCV REQUIRED)
find_package(CGAL QUIET COMPONENTS Core )
find_library(GMP_LIBRARY gmp /usr/lib)
include(src)
include( ${CGAL_USE_FILE} )
include( CGAL_CreateSingleSourceCGALProgram )
set(EXECUTABLE_OUTPUT_PATH ../bin)
set(CMAKE_EXE_LINKER_FLAGS "-static-libgcc -static-libstdc++")
include_directories( src )
include_directories( ${OpenCV_INCLUDE_DIRS} )
file(GLOB_RECURSE nei_SRC "src/*.cpp")
add_executable( nei_segmentation ${nei_SRC})
target_link_libraries( nei_segmentation ${OpenCV_LIBS} ${GMP_LIBRARY})
转载请注明原文地址: https://www.6miu.com/read-22713.html