作者:小遥2502881765 | 来源:互联网 | 2023-09-24 12:09
【背景】
基于Visual Studio环境开发的程序换一个运行环境时常常出现这样的情况:先提示“无法启动此程序,因为计算机丢失**.dll。尝试重新安装该程序以解决此问题”,很容易想到的办法就是从原来的环境中搜索相应的**.dll,然后放到当前运行环境中,如果运气好那么问题就解决了,可如果运气不好,就会继续提示“应用程序无法正常启动0xc00007b”,这是因为我们找的那个**.dll虽然名字对上了,但是版本其实不对。如果你有耐心,那么将原来环境中所有的同名dll全部尝试一遍(如图1),当然也就可以解决此问题。这种方法在上一篇同名贴中已经介绍,而且借助depends工具和everything也可以适当提升解决问题的效率。
图 1. 同名dll会有很多个版本
【方法】
但是很明显,如果程序比较庞大,依赖的dll比较多的话,这种方法是非常繁琐且低效的。我们需要从源头上找原因并解决该问题。其实之所以出现前面所述问题,根本上是因为新环境缺少了VS的运行时库,如果将相应的运行时库安装部署到新环境那么问题就迎刃而解,根本不需要关心到底是缺失了哪些dll,更不用关心是哪个版本的dll。所以解决方法也很简单,应用程序是基于那种VS开发环境开发的就下载相应版本的VS运行时库安装到新环境即可!
那么去哪里下载运行时库呢?当然是去微软官网:https://www.visualstudio.com/zh-hans/vs/older-downloads/,翻到网页最下面的”可再发行组建和生成工具“,如图2所示,基于哪个环境开发的就下载那个,然后跟应用程序一起部署到新环境下就好了。
图 2. VS运行时库的下载
【限制】
另外值得一提的是,如果前面提示丢失的**.dll是Debug版本的,比如”丢失MSVCR120d.dll“,那么用前面的方法依然无法解决该问题,这是因为这些运行时库不包含对Debug版本的支持。所以,需要注意:发布的应用程序必须为Release版本,才能用前面的【方法】解决。否则就只能采用【背景】中介绍的笨办法解决了。