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

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

概述在新的VCL应用程序中,编译和构建 *** 作会生成相同的二进制文件和映射文件(即使“项目中包含版本信息”选项已关闭,也会在.exe文件末尾略有不同 – 已经讨论过).映射文件的字节与字节相同.但是,我添加任何第三方组件,由Build和Compile生成的二进制和map(!)文件明显不同! 测试了两个版本的Delphi:   – 7.0版(Build 8.1)   – CodeGear™RAD Studi 在新的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标头时间戳以及其他填充和对齐位.

总结

以上是内存溢出为你收集整理的Delphi Compile和Build在同一个项目上生成不同的二进制文件全部内容,希望文章能够帮你解决Delphi Compile和Build在同一个项目上生成不同的二进制文件所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1272004.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-08
下一篇2022-06-08

发表评论

登录后才能评论

评论列表(0条)

    保存