使用CMAKE将共享库链接到可执行文件
Linking a shared library to an executable using CMAKE
下面是一个简单的CMake项目。在Linux上,所有内容都可以编译,运行main可以得到预期的输出。在Windows上,编译也很成功,不过main
没有给出任何输出。我真的无法解释这个错误,但当我从main
调用getNumber()
函数时,main
就不再工作了。我甚至不能在那里设置断点并调试它
|-CMakeLists.txt
|-Main
|---main.cpp
|---CmakeLists.txt
|-SHLib
|---foo.h
|---foo.cpp
|---CmakeLists.txt
CMakeLists.txt:
add_subdirectory(SHLib)
add_subdirectory(Main)
Main/CMakeLists.txt:
add_executable(Main main.cpp)
target_link_libraries(Main PUBLIC SHLib)
SHLib/CMakeLists.txt
add_library(
SHLib SHARED
foo.h
foo.cpp
)
add_compile_definitions(LIBRARY_EXPORTS)
target_include_directories(SHLib PUBLIC "${PROJECT_SOURCE_DIR}")
Main/Main.cpp
#include <iostream>
#include <SHLib/foo.h>
int main()
{
if (getNumber() == 7)
std::cout << "Successful linkingn";
std::cout << "End of main functionn";
}
SHLib/foo.h
#ifdef _WIN32
# ifdef LIBRARY_EXPORTS
# define LIBRARY_API __declspec( dllexport )
# else
# define LIBRARY_API __declspec( dllimport )
# endif
#else
# define LIBRARY_API
#endif
LIBRARY_API int getNumber();
SHLib/foo.cpp
#include <SHLib/foo.h>
int getNumber()
{
return 7;
}
要使其在Windows上运行,dll和可执行文件必须在同一文件夹中。您可以手动复制它们,也可以在顶部CMake文件中设置输出目录,如下所示:set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "yours_output_directory")
。这样,可执行文件和dll都将出现在yours_output_directory中。
相关文章:
- 如果包含映射的静态库与可执行文件和动态库链接,静态映射(变量)是否会被多次释放?
- 为什么C++可执行文件在与较新的libstdc++.so链接时运行得更快?
- 在链接可执行文件之前查找静态库未解析的依赖项
- python37.dll在可执行文件中未链接
- 调用函数一次用于动态链接库,一次从可执行文件调用函数
- 使用共享库编译可执行文件时仅链接所需的符号
- 使用 MINGW 和 CPLEX 库链接从 Linux 编译 Windows 可执行文件
- 不同的数学符号绑定与共享库与 dlopen 并直接链接到可执行文件 (Linux)
- 静态库中的符号有时会链接到可执行文件中,有时则不会
- CMake - 仅在需要时将库链接到可执行文件
- cusparse功能的多个定义错误在链接可执行文件中的cuda文件时
- G 无法将.O文件链接到可执行文件中
- 为什么 GNU ld 在链接可执行文件和共享对象时以不同的方式解析符号
- 为什么 Linux 上的动态链接可执行文件在其自己的内存空间中具有 libc 的完整内存空间
- Linaro工具链-ARM可执行文件
- c++链接器如何选择将类的哪个定义链接到可执行文件中
- 如何告诉CMake对库链接可执行文件
- 链接可执行到共享库(Android Studio 2.2)
- 用静态库的完整路径链接可执行文件
- 链接可执行文件中的共享库与另一个共享库