官术网_书友最值得收藏!

Creating a library

CMake allows us to create libraries used by the OpenCV build system. Factorizing shared code among multiple applications is a common and useful practice in software development. In big applications, or common code shared in multiple applications, this practice is very useful. In this case, we do not create a binary executable, but instead we create a compiled file that includes all the functions, classes, and so on. We can then share this library file with other applications without sharing our source code.

CMake includes the add_library function to this end:

# Create our hello library 
    add_library(Hello hello.cpp hello.h) 
 
# Create our application that uses our new library 
    add_executable(executable main.cpp) 
 
# Link our executable with the new library 
    target_link_libraries(executable Hello) 

The lines starting with # add comments and are ignored by CMake. The add_library (Hello hello.cpp hello.h) command defines the source files of our library and its name, where Hello is the library name and hello.cpp and hello.h are the source files. We add the header file too to allow IDEs such as Visual Studio to link to the header files. This line is going to generate a shared (.so for Mac OS X, and Unix or .dll for Windows) or static library (.a for Mac OS X, and Unix or .lib for Windows) file, depending on whether we add a SHARED or STATIC word between library name and source files. target_link_libraries(executable Hello) is the function that links our executable to the desired library, in our case, the Hello library.

主站蜘蛛池模板: 高平市| 虞城县| 铁岭县| 东乌珠穆沁旗| 田阳县| 金川县| 汽车| 资兴市| 禹城市| 桃园市| 宁化县| 庄浪县| 宝山区| 东阿县| 衡阳市| 广宗县| 莲花县| 珠海市| 南华县| 玉田县| 全南县| 海宁市| 铜鼓县| 许昌市| 白朗县| 大宁县| 东台市| 交口县| 南涧| 白银市| 双柏县| 新龙县| 荆门市| 鹤岗市| 南通市| 迁安市| 凤城市| 泽州县| 华宁县| 射阳县| 福贡县|