Delphi Compile和Build在同一个项目上生成不同的二进制文件
在新的VCL应用程序中,编译和构建操作会生成相同的二进制文件和映射文件(即使“项目中包含版本信息”选项已关闭,也会在.exe文件末尾略有不同 – 已经讨论过).映射文件的字节与字节相同.但是,我添加任何第三方组件,由Build和Compile生成的二进制和map(!)文件明显不同!
测试了两个版本的Delphi: 重现步骤: >创建新的VCL应用程序.可能添加任何本机Delphi组件(我尝试从Standart,Additional,Win32和System选项卡中的所有组件). 我们有几乎不同的.exe文件和完全相同的.map文件.然后,如果我们再次重复所有步骤但在项目第三方组件中使用(我尝试ODAC,DOA,DevExpress和selfmade),我们会得到更多不同的.exe和不同的.map文件. 为什么?有什么建议? UPDATE 解决方法
您所看到的只是编译器内置make逻辑的工件.当您进行构建时,它会告诉编译器构建所有可用的源.因此,Delphi处理每个源文件以及它找到源的使用列表中的每个单元,然后它将构建该文件.它以递归方式执行此操作.编译时,只加载现有的.dcu文件,如果发现它们是最新的,则不执行任何操作.这实际上可以导致发现单元的不同顺序,因为每个.dcu将有效地“展平”使用列表.由于单元是以不同的顺序被发现和加载的,因此它们是相反的,以不同的顺序链接.这就是您的地图文件看起来如此不同的原因.给定相同的源,如果您连续执行两个构建或连续两个编译,则映射文件应该相同.
造成差异的其他原因更为平凡,包括PE标头时间戳以及其他填充和对齐位. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |