程序打包之由于dll缺失导致的无法运行问题

背景

软件打包是程序成形发布的必经之路,但是常常会有软件依赖库缺失而导致的无法运行问题。

假设依赖关系如下:

graph LR A[程序A] -- 依赖 --> B[动态链接库B] B[动态链接库B]-- 依赖 --> C[动态链接库C] C-- 依赖 --> D[...]

其根本原因是因为本程序A依赖的动态链接库B的缺失,以及所依赖库文件B所依赖的库文件C的缺失,以及等等所有的依赖文件的缺失导致的!

当然有些自动化打包软件比如qt的windeployqt.exe,再比如python的pyinstaller ,但是这些工具只能将工具内包含的依赖环境自动打包,而系统环境下dll依赖不会自动打包到软件的运行路径,这里推荐depends.exe 自己观察依赖库文件都有哪些。depends的下载地址为:http://www.dependencywalker.com/

实际操作过程中,比如使用windeployqt打包的程序在当前Windows环境下是可以直接运行的,但是由于Windows环境不一样,比如更换电脑之后。所以需要将所需要的全部的dll文件全部拷贝到当前*.exe运行的同一路径下或者exe所包含的所有路径下。

技巧

技巧是使用depends在进行开发的Windows环境下查看所依赖的dll,并且通过查看dll是否为系统路径下,如果是的话尽量拷贝到当前软件的运行路径下,当然也可以在目标上位机下,查看缺失什么dll文件,然后在进行开发的Windows环境下查看相应的位置并拷贝。

使用方法

使用方法很简单:打开depends.exe之后,点击file打开exe文件,他便会自动分析。

depends的软件界面如下,下面是拿我编写的influxdb qt工程的编译结果进行测试的,可以看出了该软件的全部依赖dll文件,并且可以查看所依赖dll本身依赖的库文件。对于Qt使用MySQL后打包程序出现的错误,我在博文打包Qt程序后调用MySQL时出现 QMYSQL driver not loaded进行了介绍,感兴趣的朋友可以关注一下。
在这里插入图片描述

任世事无常,勿忘初心
原文地址:https://www.cnblogs.com/FlameBlog/p/14715383.html