加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Delphi Compile和Build在同一个项目上生成不同的二进制文件

发布时间:2020-12-15 09:46:29 所属栏目:大数据 来源:网络整理
导读:在新的VCL应用程序中,编译和构建操作会生成相同的二进制文件和映射文件(即使“项目中包含版本信息”选项已关闭,也会在.exe文件末尾略有不同 – 已经讨论过).映射文件的字节与字节相同.但是,我添加任何第三方组件,由Build和Compile生成的二进制和map(!)文件
在新的VCL应用程序中,编译和构建操作会生成相同的二进制文件和映射文件(即使“项目中包含版本信息”选项已关闭,也会在.exe文件末尾略有不同 – 已经讨论过).映射文件的字节与字节相同.但是,我添加任何第三方组件,由Build和Compile生成的二进制和map(!)文件明显不同!

测试了两个版本的Delphi:
? – 7.0版(Build 8.1)
? – CodeGear?RAD Studio 2007版本11.0.1902.0471(2007年12月更新)

重现步骤:

>创建新的VCL应用程序.可能添加任何本机Delphi组件(我尝试从Standart,Additional,Win32和System选项卡中的所有组件).
>在项目选项的链接器选项卡上打开详细地图文件.
>建立项目.
>重命名输出.exe和.map文件(例如:project1.exe到project1b.exe,project1.map到project1b.map).
>编译项目.
>重命名输出.exe和.map文件(例如:project1.exe到project1c.exe,project1.map到project1c.map).
>比较步骤4和6中的文件.(我使用WinMerge
2.12.4.0).

我们有几乎不同的.exe文件和完全相同的.map文件.然后,如果我们再次重复所有步骤但在项目第三方组件中使用(我尝试ODAC,DOA,DevExpress和selfmade),我们会得到更多不同的.exe和不同的.map文件.

为什么?有什么建议?

UPDATE
关于我如何找到这个以及为什么它让我感兴趣的一些信息:
Project是使用MSBuild从简单的脚本构建的.当在项目中添加了通过ITE(带有资源的dll)的翻译时,我发现当项目是Build(来自脚本或来自IDE)时 – 翻译版本工作错误 – 按钮,标签等上的某些文本来自错误的地方(字面意思来自另一个按钮,标签).当项目从IDE编译时 – 一切正常.所以我开始比较Build和Compile输出……

解决方法

您所看到的只是编译器内置make逻辑的工件.当您进行构建时,它会告诉编译器构建所有可用的源.因此,Delphi处理每个源文件以及它找到源的使用列表中的每个单元,然后它将构建该文件.它以递归方式执行此操作.编译时,只加载现有的.dcu文件,如果发现它们是最新的,则不执行任何操作.这实际上可以导致发现单元的不同顺序,因为每个.dcu将有效地“展平”使用列表.由于单元是以不同的顺序被发现和加载的,因此它们是相反的,以不同的顺序链接.这就是您的地图文件看起来如此不同的原因.给定相同的源,如果您连续执行两个构建或连续两个编译,则映射文件应该相同.

造成差异的其他原因更为平凡,包括PE标头时间戳以及其他填充和对齐位.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读