gpt4 book ai didi

delphi - 将应用程序转换为 BPL,现在应用程序在 Application.Initialize 之前终止

转载 作者:行者123 更新时间:2023-12-01 16:26:01 25 4
gpt4 key购买 nike

我有一个 VCL Forms 应用程序,其中包含对我创建的 BPL 文件的引用。我将 BPL 中的框架组件的单元名称添加到 VCL 应用程序主窗口的 use 子句中。该应用程序构建得很好,但是当我运行它时,它在到达项目文件中的第一行“Application.Initialize”之前就死掉了。如果我从 use 子句中注释掉框架的单位,应用程序将启动并运行良好。

什么可能导致应用程序启动时出现 fatal error ?

我猜测启动时加载 BPL 文件存在问题,但我无法找到问题。谢谢。

下面有更多信息...VCL 应用程序位于 XE5 中,我正在尝试将其转换为 BPL。整个应用程序驻留在一个 TFrame 控件中,该控件包含许多其他按钮和框架,可以访问应用程序的所有底层功能。然后,这个“主框架”被放置在应用程序的主窗体中,除了几个菜单项之外,该主窗体是空的。原始应用程序构建并运行良好。

我创建了一个新的 BPL 项目,并添加了这个“主框架”组件,以创建一个 BPL 包,该包本质上是我的整个应用程序,并且可以像以前一样用于普通的独立 exe 应用程序,或者被添加到 RemObjects Hydra 插件模块中,并最终嵌入到 C# 应用程序中。具有单个“主框架”组件的 BPL 项目构建良好,没有错误。

然后,我使用一个空的主窗体创建了一个新的 VCL Forms 应用程序,并设置项目的“选项->包->运行时包”以包含我的新 BPL,并选中“与运行时的链接”时间套餐”选项。我将“主框架”单元添加到主窗体的使用子句中,并且所有内容都构建没有错误。

问题:当我从 XE5 运行应用程序时,它似乎开始正常启动,但在到达第一行代码“Application.Initialize;”之前它就死掉了。在项目文件中。请注意,我还没有编写任何代码来创建 BPL 中“主框架”的实例。我只是将其单位添加到了 use 子句中。不显示任何错误消息,并且 XE5 中的“构建”或“输出”窗口中不会发布任何内容。如果我从 use 子句中注释掉“主框架”单元,则应用程序运行正常,并显示空的主窗口。

注意:该应用程序使用 JVcl、NativeXml、TsiLang、ZipForge 和 FastReports。

最佳答案

您描述的症状是加载时间依赖性解析失败的症状。根据您的描述,这很可能是由于加载时未找到您的 BPL 文件。加载时包依赖性由系统加载器处理,因此 DLL 搜索顺序适用。通常,您会确保依赖模块与可执行文件位于同一目录中。

在调试器下运行时,无法很好地处理加载时间依赖性故障。如果直接启动可执行文件,您会收到更好的错误消息。如果这还不足以识别问题,请在配置文件模式下使用 Dependency Walker 来获取任何加载时间错误的详细诊断信息。

关于 Embarcadero 关于包部署的建议的最后评论。官方Embarcadero documentation仍然建议将共享包安装到系统目录。虽然这在 20 年前的 Windows 3.1 中是常见做法,但在 21 世纪没有人应该这样做。请不要遵循 Embarcadero 的这一特定建议,并请尊重系统目录属于系统的事实。

关于delphi - 将应用程序转换为 BPL,现在应用程序在 Application.Initialize 之前终止,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22680363/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com