扫盲
静态链接库是什么?
将自己设计的类导出为二进制形式的可执行代码。静态链接库有两种形式
- MSVC编译器生成的文件后缀为 ".lib"
- MinGW编译器生成的文件后缀为 ".a"
何种场合下使用静态链接库?
在小组开发时,各成员将自己开发的类导出,供其他成员使用。他人只能使用你写的类,不能修改和查看源码,方便项目代码的管理。
使用静态链接库
在应用程序中使用一个静态链接库,只需".lib"文件和类的头文件,不需要.cpp源文件
使用Qt Creator创建静态链接库
-
创建按静态链接库项目
通过项目创建向导创建一个静态链接库项目,如下图所示
- .pro文件说明
pro文件中内容如下
TEMPLATE = lib 项目模板是库,不是应用程序
CONFIG += staticlib 项目配置为静态库 - 关于最终生成的文档
Debug还是Release模式下生成的文件名称相同,Debug下变异的程序不会添加字母“d”,但是在release和debug模式下使用静态链接库时,应使用相应的模式下导出的库文件。 - 添加自己的类
将项目配置时自动生成的类删除,并添加自己写好的类即ui文件。此步骤在pro文件中进行。
笔者这里使用的类的功能是一个获取QPen的对话框,用户可以在这个对话框中选择线条类型、颜色、宽度等,类名为QPenDialog。由于这里使用的类包含ui文件,所以源文件有三个,分别是 .h .cpp 和.ui文件。下面分步骤展示lib文件的生成方法。-
将写好的类复制到项目文件夹下,共包含三个文件qpendialog.h qpendialog.cpp qpendialog.ui
-
在pro文件中添加这3个文件
-
分别在debug和release模式下编译生成lib文件
-
将lib文件和.h头文件复制出备用
-
- 编写pri文件
Qt中可以使用pri文件引入第三方库,新建一个文本文件,重命名为"qpendialog.pri"输入头文件和lib路径即可
INCLUDEPATH += C:/Users/cnqdf/Desktop/qpendialog
Debug: {
LIBS += -lC:/Users/cnqdf/Desktop/qpendialog/staticLibd
}
Release: {
LIBS += -lC:/Users/cnqdf/Desktop/qpendialog/s![002.gif](https://upload-images.jianshu.io/upload_images/9031828-0747d6e3b5db666a.gif?imageMogr2/auto-orient/strip)
taticLib
}
- 创建一个应用程序
这里过程就不说了,随便创建一个QMainWindow的程序就可以,主要是为了测试静态链接库的。在此程序的pro文件中添加一行:
include("pri文件路径/qpendialog.pri")
执行qMake,确保pri文件被引入
-
包含头文件,使用静态链接库
笔者这里使用的是静态链接库中的一个getPen函数,调用此函数时弹出Pen选择对话框。
-
测试程序是否运行正常
最后一步测试以下静态链接库是否运行正常
笔者的静态链接库是一个获取QPen的类,如果获取正常,则在主窗口使用刚刚获取的线型等绘制一个矩形。注意需要在debug和release模式下分别测试,若都运行正常则此静态链接库导出成功。
博客中源码下载链接 点我