- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我构建了一个动态链接到多个 DLL 的可执行文件。其中大部分默认安装在 Windows 上,但版本可能略有不同。其他的我随应用程序分发,但它们可能又依赖于其他 DLL。
如果我在本地运行可执行文件并收到 Windows 错误消息“无法加载 [whatever]。应用程序配置不正确”,这似乎意味着缺少“whatever”所依赖的库。但它(相当令人恼火)忽略了准确指定它在加载时遇到问题的 DLL。有时我可以使用 Dependency Walker 来解决这个问题查看是否有明显缺失的库。其他时候,我可以诉诸 Process Monitor这可以告诉我 Windows 在发出错误消息之前正在寻找哪个文件。
但是,当最终用户尝试诊断他们的问题时,这些并不是最终用户必须使用的合理工具。有什么方法可以让 Windows 准确地说出它在解析时遇到问题的库,以便可以将其输出到日志或显示在消息框中?
最佳答案
根据我的经验,此类错误的一个常见原因是意外运送了一个链接到 C 运行时调试版本的组件,该版本明确不可再分发,因此只有在最终用户的系统上,如果他们碰巧安装了匹配版本的 VisualStudio。它的名称类似于 MSVCR80D.DLL
而不是 MSVCR80.DLL
。
Dependency Walker 无疑是开发人员用来检查可执行文件的正确工具。它可以 Hook 应用程序以获取 DLL 加载事件并运行它,因此您可以发现在运行时动态加载的 DLL 以及在构建时命名的 DLL。
Dependency Walker 也是可编写脚本的,并且可以写入日志文件。我将这种方式用作构建过程的一部分,以在打包发布之前验证发货。我将所有要传送的文件暂存到它们传送的目录树的模型中。我使用 dependency walker 托管的应用程序 Debug模式,使其加载所有可选的点点滴滴,然后退出。 Depends.exe 给我留下了一个很好的日志文件,我用 Perl 脚本检查它,如果从系统上的任何地方加载任何 DLL 而不是 \WINDOWS
或暂存区域,或者如果一个加载了意外版本或调试版本的 C 运行时。只有在检查成功后,我才会构建将要发布的 InnoSetup 安装程序包。这已经避免了几次尴尬,并且非常值得为弄清楚该怎么做而付出的努力。
如果您知道每个 DLL 要么是“官方”Windows DLL 要么是您发货的一部分,那么您就很有可能在客户的机器上正常工作。
编辑: Dependency Walker 的官方主页是个四处闲逛的好地方。那里提供的版本可能比 MSVS 附带的版本更新,并且有大量关于高级用途的不错的文档。
我可以确认我已经在 depends.exe 下运行了 IE,但根本没有进行太多测试。
关于windows - 在最终用户系统上调试 "application configuration is incorrect"问题的好方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3178729/
我正在使用 Ubuntu 16.04。 当我更新时,我收到以下消息 $ sudo apt-get update .... E: dpkg was interrupted, you must manua
似乎有些autoconf项目使用configure.in文件生成configure脚本,有些使用configure.ac。 使用一种或另一种之间的区别/优势是什么? 最佳答案 这只是风格问题。历史上
我正在尝试按如下方式配置 logback,但它抛出了这个错误。配置文件如下: %d{ISO8601} %-5p [%c] %msg%n
从Miguel de Icaza: We use a library profile that is better suited for mobile devices, so we removed f
我有两个 .config 文件,我需要一个 System.Configuration.Configuration那是它们之间的部分合并? 我可以将文件读取为 XML 并轻松创建所需的合并,但它是一个字
我似乎无法理解这两个注释。我尝试阅读 javadocs 但仍然无法弄清楚。任何人都可以用简单的代码来解释这两个吗? 非常感谢。 最佳答案 您使用 @Configuration作为配置 Spring b
我正在为一个简单的问题而焦头烂额。我的 .NET Core 3 应用程序中有一些设置,我认为最好将其移至我的 appsettings.json 文件。我按照本指南这样做:https://www.c-s
我正在为一个简单的问题而焦头烂额。我的 .NET Core 3 应用程序中有一些设置,我认为最好将其移至我的 appsettings.json 文件。我按照本指南这样做:https://www.c-s
我有以下测试方法: [TestMethod] public void TestHarvestMethod() { HarvestTargetTimeRangeUTC time = new Ha
我的以下代码没有产生预期的输出: public static void main(String[] args) throws MalformedURLException { Configura
我知道要从源代码编译和安装某些东西,在 Unix 系统中,涉及的三个步骤是: 1) ./configure 2) make 3) make install 当我检查OpenCV from source
我有以下片段: static void Main(string[] args) { var container = new UnityContainer(); container.Re
我想好像 apache 的 commons-configuration 可能/支持从属性文件中获取属性作为 map 到目前为止,我已经设法使用以下代码片段间接地做到了这一点 Map map = ne
我正在寻找任何技巧来使用 CKEditor 配置中的参数配置我的插件。我必须传递一些只能在显示 View 时传递的参数。 我想要这样的东西(带有 jQuery 适配器的示例): jQuery('t
在我正在玩的代码中,我看到一些地方是 @Configuration 类除了定义静态类之外什么都不做。格式各不相同,但通常是这样的: @Configuration public class someAu
我们在带有 JRE 7 的 Windows 7 中安装了 Cassandra 2.0.6,我们更新了 cassandra.yaml 文件,如下所示: 数据文件目录:D:\cassandra_data\
我在启动类中收到“'Startup.Configuration' 和'Startup.Configuration' 之间的歧义”错误。我不知道我做了什么导致这个问题。我所做的只是创建了一个 DBCon
我已经安装了 Cygwin64,现在我想安装 extundelete . 所以我下载了它,解压了文件,但是当我运行 ./configure 时它说: $ ./configure Configuring
为什么需要做(在容器目录内): # cd /container/directory/ # ./configure 代替: # pwd /external/path # /container/direc
我正在尝试编译qucs-0.0.19但是当我放置./configure时,它给了我以下错误: checking Checking if admsXml is working... no config
我是一名优秀的程序员,十分优秀!