Qt中LNK2019错误的解决办法
2023-06-13 09:15:04 时间
在写Qt 网络编程的程序时,有时候会遇到
dialog.obj:-1: error: LNK2019: 无法解析的外部符号 "__declspec(dllimport) public: virtual __cdecl QNetworkAccessManager::~QNetworkAccessManager(void)" (__imp\_??1QNetworkAccessManager@@UEAA@XZ),该符号在函数 "protected: void __cdecl Dialog::slotLogin(void)" (?slotLogin@Dialog@@IEAAXXZ) 中被引用
这类的错误,让人十分头大。
这个错误大多是因为没有按照要求导入相应的链接库,以至于无法调用相应的类库。在vs或者codeblocks环境下可以通过选项设置之类的东西添加相应的链接库。但是在Qt Creator默认是没有这种东西的,而是提供了另一种途径,即每个项目必然会有的.pro文件,类似于:
#-------------------------------------------------
#
# Project created by QtCreator 2015-10-29T23:52:56
#
#-------------------------------------------------
QT += core gui
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
TARGET = Dialog
TEMPLATE = app
SOURCES += main.cpp
dialog.cpp
HEADERS += dialog.h
这个文件主要是给qmake用的,具体也没有必要了解。一般是系统生成的默认值就行了,只有当我们需要导入链接库的时候才有用。比如当我们需要用QNetworkAccessManager这个类的时候,我们需要在这当中加入一句话:QT += network
即可,这样在构建的时候就会导入network这一系列的库。这个network从哪来的呢?实际上,在Qt Creator自带的帮助文档中已经告诉我们了,在QNetworkAccessManager中有相应的说明:
Header: #include <QNetworkAccessManager>
qmake: QT += network
Since: Qt 4.4
Inherits: QObject
有了这个说明,那么解决方案就很明显了。
但是还有一点需要注意,就是在修改过.pro 文件之后,需要手动将系统之前在上一级目录下生成出来的build文件夹删除之后才能使该文件生效。
相关文章
- QT 5.9.0下载安装及配置教程
- qt串口通信接收数据不完整_qt串口接收数据
- QT计算器 之 大数运算「建议收藏」
- Qt截图软件2-实现截全屏功能
- C/C++ Qt TableWidget 表格组件应用
- PyQt5安装以及使用教程 (window 上含QT Designer的安装)
- Qt编译错误:底层由于接收到操作系统的信号而停止indows
- Ubuntu18.04下Qt出现qt.qpa.plugin:Could not load the Qt platform plugin “xcb“问题解决方法
- 编程在Linux下学习Qt界面编程(linux下qt界面)
- 使用Qt快速设置Linux时间(qt设置linux时间)
- 使用Qt框架轻松连接MySQL数据库(qt与mysql连接)
- Linux下 Qt 安装指南(linux下qt的安装)
- Qt 实现 Linux 串口通信编程(qt串口linux)
- 在Linux上体验Qt的魅力(linux下运行qt)
- Linux下Qt源码编译实践(qt源码编译linux)
- Qt操作MYSQL:只需几步就能实现(qt操作mysql)
- Qt 静态编译在 Linux 的实践(qt静态编译linux)
- Linux下Qt实现串口通信(linux下qt串口)
- 使用 Qt 连接 MySql (qt使用mysql)
- 简明易懂的Linux下QT安装指南(linux下安装qt教程)
- 在Linux上开发应用程序:Qt系列版本深入解析(linux版本qt)
- Linux下Qt发布程序:一步一步教你操作(linuxqt发布程序)
- 配置Linux的QT环境变量,轻松打造高效开发环境(qt环境变量linux)
- 使用Qt框架插入MySQL中的数据(qt插入mysql)
- Qt 5 与 MySQL 数据库联合使用:简单高效的开发实践(qt 5 mysql)
- 轻松实现QT直连Microsoft SQL Server(qt直连mssql)
- MySQL和QT不配套使用,无法实现事务处理(mysql不支持qt事务)
- Redis使用Qt解决读写互斥问题(redis读写互斥qt)