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

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.

主站蜘蛛池模板: 界首市| 石泉县| 新和县| 徐州市| 依兰县| 临泉县| 邵武市| 洪洞县| 和硕县| 黔江区| 民丰县| 库尔勒市| 会同县| 资溪县| 宝应县| 兰坪| 淮阳县| 图木舒克市| 裕民县| 麻江县| 荆州市| 紫云| 汪清县| 岳阳市| 静海县| 济阳县| 廉江市| 成武县| 沙田区| 大同市| 洛川县| 峨边| 晋城| 霍州市| 清流县| 襄城县| 化州市| 肇庆市| 石嘴山市| 巴里| 天峻县|