介绍

windeployqt.exe是Qt自带的工具,用于创建应用程序发布包。
简单来说,这个工具可以自动地将某程序依赖的库、资源拷贝到其所在目录,防止程序在其他电脑上运行报找不到库的错误。
这里贴上官方文档:https://doc.qt.io/qt-5/windows-deployment.html

原理

windeployqt.exe工作原理很简单,它会到当前的环境变量PATH配置的搜索路径中,查找应用程序所需要的库和资源,拷贝到应用程序目录中。

使用

1、先从开始菜单中打开对应版本的Qt命令行终端界面,如下图:

2、命令行中输入

windeployqt.exe 应用程序完整路径

我们知道,Qt项目路径不能包含中文,所以为了保险起见,应用程序路径中不要包含中文。另外,如果应用程序路径中包含空格,需要用双引号将整个路径字符串包裹起来。

回车即可执行发布命令。输出界面如下图所示:

进入到应用程序目录可以看到,目录中增加了很多依赖库和数据文件。如下图所示:

大体上的流程只有这两步。
整个发布过程看似比较简单,但是其中还是存在一些坑的。

坑点一:未使用Qt的命令行终端执行发布命令,导致库版本拷贝错误

下面是直接使用系统cmd命令行发布软件的过程:

直接打开cmd命令行,进入到windeployqt.exe所在目录
输入:windeployqt.exe 应用程序完整路径,回车。

这样发布出来的应用程序可能会崩溃或者出现以下问题:

面对这个错误没有经验的话,很难解决,特别是软件直接崩溃的话,更无从下手。要解决这个问题,估计至少要半天时间。

0xc000007b是一个经典错误,它代表着程序启动时使用了不正确的版本的库,导致无法正常运行。例如,64位的软件使用了32位的库。

所以,发生上面错误的原因是,windeployqt.exe从系统的环境变量路径PATH中找到了其他版本的依赖库,而这个依赖库并不是我们的应用程序真正依赖的那个版本。当你的计算机中安装了很多软件,某些软件会添加系统环境变量,指向自己的bin目录;抑或是安装了几个版本的Qt开发环境时,难免会导致搜索路径中有同名称的、不同版本的库存在,这些情况下,库版本错乱的问题经常发生。

在Qt命令行中输入 echo %PATH%,可以查看当前Qt使用的环境变量:

上图中红色框内是此版本Qt的库文件目录,已添加到当前PATH环境变量的最开头,将会被windeployqt.exe优先搜索到。如此一来,Qt相关的库便不会产生库版本错误的问题。

坑点二:未使用与Qt版本对应的windeployqt.exe

发布软件时,必须确定项目开发所使用的Qt版本,并使用此版本Qt安装目录下的windeployqt.exe完成发布过程。每个Qt版本中的工具只有在此Qt版本下才能确保正常工作,混用会引入未知的风险。

坑点三:发布时,默认文件不会覆盖

在Qt命令行终端中多次执行发布命令时,已发布到应用程序文件夹中的文件默认不会被覆盖。当你第一次发布出问题时,调整好环境后再次发布并不会覆盖已存在的文件。这可能和我们期望的不太一样。可以通过添加强制覆盖参数–force强制覆盖已存在的文件,如下图所示:

建议始终添加–force参数,防止因文件未覆盖而出现问题。

细节问题

Qt命令行启动时有一行提示:

上面打包输出界面的红框中,有这样一行警告:

Warning: Cannot find Visual Studio installation directory, VCINSTALLDIR is not set.

意思是说,因为我们没有运行vcvarsall.bat,所以VS的环境变量没有配置好,所以不会拷贝VS相关的依赖库。

vcvarsall.bat是VS的自带的配置环境变量的批处理文件。以VS2010为例,它位于路径 C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC 下。它属于VS命令行工具的一部分,这里不多说,直接去看VS官网文档即可:通过命令行使用 Microsoft C++ 工具集。

那我们就尝试运行vcvarsall.bat来配置一下VS的环境。整个过程的完整操作过程界面如下:

可以看到,那一行警告不见了。同时,应用程序目录下多了两个库文件,如下图:

这样发布出来的目录就带上了VS的依赖库,拷贝到没有安装VS的电脑上亦可以运行。

命令帮助

除本文提及的基本参数,发布程序还提供了一些额外参数选项,可以通过查看命令帮助了解。

在Qt命令行终端中输入

windeployqt.exe -h

可以查看命令帮助,如下图所示:

限于篇幅,这里不再进一步讲解,大家可以自己动手尝试。

结语

总体来说,虽然发布步骤比较简单,但是有坑有细节,自己尝试操作几次就能熟悉了。里面的坑笔者踩过,会浪费很多时间,希望大家能避免踩坑,提高效率。

本文原创首发于公众号/头条号 Qt未来工程师。

windeployqt.exe的使用与避坑(windows平台)相关推荐

  1. Python+Selenium 网页自动化 exe 程序编程实现(最全避坑指南)

    前言 在我的日常工作中,经常需要在内网(不连接互联网)的网页版办公系统中进行抓取网页数据.修改表单等大量重复性的操作.我就想是否可以编写出自动化的工具,将这些日常琐碎的操作变得轻松而高效.虽然本人非计 ...

  2. 【A卡,Windows】stable diffusion webui下载安装避坑指南

    观前提醒 本文内容都是本人亲身经历的,一个一个安装下载测试所感,当然如果你更想用傻瓜式集成包的,那还是跳过这篇文章吧. 当然我不推荐这篇文章的操作,因为我用了差不多1h才有一副图,有N卡,就用N卡,这 ...

  3. Python打包工具Pyintealler打包py文件为windows exe文件过程及踩坑记录+实战例子

    Python打包工具Pyintealler打包py文件为windows exe文件过程及踩坑记录+实战例子 目录 Python打包工具Pyintealler打包py文件为windows exe文件过程 ...

  4. 【吐血经验】在 windows 上安装 spark 遇到的一些坑 | 避坑指南

    在 windows 上安装 spark 遇到的一些坑 | 避坑指南 最近有个活:给了我一个阿里云桌面(windows 10系统),让我在上面用 scala + spark 写一些东西. 总是报错不断, ...

  5. android手机配什么蓝牙耳机,Airpods Pro搭配安卓手机+Windows电脑服用指南(避坑指南)...

    Airpods Pro搭配安卓手机+Windows电脑服用指南(避坑指南) 2019-12-17 16:01:32 57点赞 104收藏 75评论 创作立场声明:本篇内容仅基于本人AirPods Pr ...

  6. 虚拟服务器windows硬盘30t,避坑指南:基于Windows系统的NAS通过NFS将硬盘空间共享给Hyper-V黑群晖...

    避坑指南:基于Windows系统的NAS通过NFS将硬盘空间共享给Hyper-V黑群晖 2019-07-08 07:30:00 64点赞 601收藏 91评论 方案选择 首先感谢矿难,性价比超高的蜗牛 ...

  7. windows下pycocotools的安装及避坑

    windows下pycocotools的安装及避坑 本文原地址: https://aistudio.baidu.com/aistudio/projectdetail/980509 (保持更新) 1. ...

  8. kali子系统安装教程(包含避坑指南,新手必看!)

    #版权声明:图中含有知乎@王维同学字样的,是我在知乎的号,不是盗的文章!这篇文章比知乎更详细!! 1.开启安装Linux子系统需要的扩展 Win+Q搜索功能 勾选需要的扩展,Hyper-V.Windo ...

  9. 17条避坑指南:一份来自谷歌的数据库经验贴

    点击上方蓝色"程序猿DD",选择"设为星标" 回复"资源"获取独家整理的学习资料! 来源 | https://medium.com/@rak ...

最新文章

  1. Matlab与线性代数 -- 数组的表示,冒号的用法
  2. python 之模块引入
  3. BZOJ-1880-Elaxia的路线-SDOI2009-SPFA+拓扑排序
  4. python DB.fetchall()--获取数据库所有记录列表
  5. 使用阿里云加速docker镜像的安装
  6. VB/VBA中实现数据库与文件的存取
  7. 2021年1月DB-Engines流行度排行:Snowflake五倍跃迁 Azure SQL云数据库倍增
  8. python计算蛋白质的质量
  9. 百度echarts极速入门
  10. 土壤HWSD处理流程
  11. 微信小程序 图片上传预览删除
  12. 未成年人勿进 谨以献给1980~1990出生的人(五)
  13. 支付宝app登录授权的infoStr授权登录流程
  14. 漫画电子电路读书笔记
  15. Google Earth Engine ——基于ENVISAT的中分辨率成像光谱仪全球土地覆盖300米分辨率数据集
  16. 亲测有效的UCOSIII嵌入STM32F103C8T6实验,介绍常见移植问题,付实测代码!!!
  17. 启动3dMax时一直停留在启动屏幕并显示文本“starting 3ds Max…”怎么办?
  18. ios调用第三方程序打开文件,以及第三方调用自己的APP打开文件
  19. 阿里云ACP/ACE在线考试规定(考生须知)
  20. ROS安装全过程(十分壮观,是个大坑来的

热门文章

  1. Web应用中request获取各种获取path或URI,URL的方法
  2. 嵌入式linux调试技术
  3. sqlserver查看被锁表、解锁
  4. DIY_DE2开发板介绍
  5. C#连接数据库SQL(2005)
  6. [计算机网络][总结][常见问题][TCP][三次握手][四次挥手]
  7. gdal 压缩tif_Python | GDAL处理影像
  8. redis实现轮询算法_【07期】Redis中是如何实现分布式锁的?
  9. 一建机电实务教材电子版_20年一建其实并不难,官方出版:复习题集(精修),速做速提90分...
  10. git 使用writer_GitHub - Vpredictor/WriterFly: [QT/C++] 写作天下,为作家创造世界而生,执云作笔,诉尽平生意。...