概述
- win 下动态链接库的后缀为 xxx.dll, 静态库为 libxxx.a
静态库
生成
- pro 文件中增加:
TEMPLATE=lib
CONFIG += staticlib
- 生成 libxxx.a 文件.
使用
- 需要 .h 和 .a 文件. eg: myTest.h 和 libmytest.a
- pro 文件中:
- Win:
LIBS += -L ../路径/ -llibmytest
- linux:
LIBS += -L ../路径/ -lmytest
- Win:
- 在程序中: 包含头文件, 直接使用类.
动态库
生成
- 有些系统需要在符号的声明中增加导入导出标记. Qt为了实现代码跨平台, 提供了以下两个宏. 但我们不需要直接使用这两宏.
Q_DECL_EXPORT
: 需要将该宏添加到编译共享库使用的符号声明中.Q_DECL_IMPORT
: 需要添加到编译使用共享库的客户端时使用的符号声明中.
- 使用 Qt Creator 创建一个动态库工程时(eg: myTest), 将会生成 myTest.Pro, myTest.h, myTest_global.h, myTest.cpp 文件.
- 编译生成: myTest.dll, libmyTest.a 其中 .a文件为静态库.
myTest.pro
定义了xxx_LIBRARY
宏(eg: MYTEST_LIBRARY).
#...
TARGET = myTest
TEMPLATE = lib
DEFINES += MYTEST_LIBRARY
#...
myTest_global.h
通过是否定义xxx_LIBRARY
来分别definexxxSHARED_EXPORT
.
#include <QtCore/qglobal.h>
#if defined(MYTEST_LIBRARY)
# define MYTESTSHARED_EXPORT Q_DECL_EXPORT
#else
# define MYTESTSHARED_EXPORT Q_DECL_IMPORT
#endif
myTest.h
在要导出的符号声明中增加xxxSHARED_EXPORT
宏.
#include "myTest_global.h"
MYTESTSHARED_EXPORT int Func(void);
class MYTESTSHARED_EXPORT MyTest ...
使用
- 需要 .h 文件 和 .dll 文件.
- 在 Qt Creator 中使用, 可修改 pro 文件:
- 在编写代码时, 需要include头文件. 可以使用
INCLUDEPATH += 头文件路径
- 需要在编译时告诉编译器 dll 位置:
LIBS += path/test.dll
- 需要程序在运行时可找到 dll: 将dll复制到exe当前位置.
- 在编写代码时, 需要include头文件. 可以使用
- 在 VS 中使用:
- C/C++ 附加包含目录中添加头文件路径.
- 链接器-附加库目录中增加 dll路径.
- 将dll复制到exe当前位置.