【发布时间】:2011-09-28 12:16:12
【问题描述】:
十多年来,我的公司一直在用 Delphi 运行一个大型项目。我们的代码库多年来一直在增长,现在大约有 400 万行代码。编译速度正在成为一个问题。我们已经花时间清除单元循环引用(编译速度慢的一个已知原因),并检查了设置的各个方面。它已经到了我们无法控制的程度。
目前,在运行 Windows XP SP3 和 Delphi 2006 的 4 核 PC 上,重新启动 Delphi 并进行完整构建,大约需要 40 秒。然后,如果我们立即在同一个 Delphi 会话中进行另一个完整构建,则需要 1m 40s。再做一个完整的构建,它会变得更糟。以此类推。
(我们很清楚Windows本身是缓存文件的,这对编译速度有很大的影响。上图是基于文件被缓存的情况。我们通过让Delphi编译一次项目来设置这样的场景,终止然后开始一个新的 Delphi 会话。因此,虽然 40 秒看起来并不慢,但这只是因为文件被 Windows 缓存了。我们这样做是为了进行苹果与苹果之间的比较。)
让我们困惑的是为什么编译速度会变差。 (我们过去观察到,如果项目有很多单元循环引用,速度会更慢。)如果我们终止 Delphi 并开始一个新会话,编译时间将回到 40 秒。我们观察到的更有趣的事情是,我们可以通过单击“取消”按钮中止编译然后立即进行完整构建来实现相同的速度“改进”。编译时间也将回到 40 秒。
在我们看来,Delphi 自己的单元依赖缓存不如从头构建它高效,而且随着时间的推移它变得越来越糟。它还显示取消按钮以某种方式清除此缓存。我们的想法是,如果我们可以利用执行此清除的 Delphi IDE 子系统,我们可以始终将编译速度保持在其峰值性能。但我们不知道怎么做。
有人知道我们能做什么吗?
我们仍在使用 Delphi 2006,因为我们还没有找到将我们的大型项目移植到 Unicode 的可行方法。我在论坛上读到,最新的 Delphi XE 在单元循环引用方面表现出类似的编译速度问题。有谁知道 Delphi XE 是否解决了这个问题?
附言我们还知道,将项目拆分为运行时包可以减少编译时间。但出于部署和管理原因,我们尽量避免使用运行时包。
【问题讨论】:
-
您是否排除了在 IDE 中运行的杀毒软件、索引软件和第 3 方专家?
-
你考虑过命令行编译器吗?
-
关于单元引用的剔除,您是手动进行的吗?如果是这样,你应该试试 CnPack 的 Uses Cleaner。 (我没有遇到过问题,但在开始之前备份你的文件不会有什么坏处)
-
请注意,“最先进的 4 核 PC”在这里并没有多大帮助。 Delphi 编译器将只使用一个内核,因此使用更快的内核会更好。即在其他条件相同的情况下,采用双 3.33 Ghz 而非四 1.8 Ghz。
标签: performance delphi compilation