/GL(全程序优化)
更新:2007 年 11 月
启用全程序优化。
/GL[-]
备注
全程序优化允许编译器用有关程序中所有模块的信息执行优化。如果不执行全程序优化,则基于每个模块 (compiland) 执行优化。
默认情况下,权全程序优化是关闭的,因此必须显式地启用它。但是,也可以用 /GL- 显式地禁用它。
使用有关所有模块的信息,编译器能够:
跨越函数边界优化寄存器的使用。
更好地跟踪对全局数据的修改,允许减少加载和存储的数目。
更好地跟踪可能由取消指针引用所修改的项组,减少加载和存储的数目。
在模块中内联某个函数,即使该函数在另一个模块中定义。
用 /GL 生成的 .obj 文件将不可用于 EDITBIN 参考 和 DUMPBIN 参考 等链接器实用工具。
如果用 /GL 和 /c(编译但不链接) 编译程序,应使用 /LTCG 链接器选项创建输出文件。
/Z7、/Zi、/ZI(调试信息格式) 不能与以下的项一起使用: /GL
以后的 Visual C++ 版本可能无法读取用当前版本中的 /GL 生成的文件格式。不应提供由用 /GL 生成的 .obj 文件组成的 .lib 文件,除非您永远愿意为希望用户使用的所有 Visual C++ 版本提供 .lib 文件的副本。
用 /GL 生成的 .obj 文件和预编译的头文件不应该用于生成 .lib 文件,除非将在生成 /GL .obj 文件的同一计算机上链接此 .lib 文件。链接时需要 .obj 文件的预编译头文件中的信息。
有关可用优化和全程序优化的限制的更多信息,请参见 /LTCG(链接时代码生成)。/GL 还使得按配置优化可用,请参见 /LTCG。 按配置优化进行编译时,如果希望函数按配置优化排序,则必须使用 /Gy(启用函数级链接) 或隐含使用 /Gy 的编译器选项进行编译。
在 Visual Studio 开发环境中设置此链接器选项
- 有关如何在开发环境中指定 /GL 的信息,请参见 /LTCG(链接时代码生成)。