两种流行的 Go 编译器“gc”和“gccgo”之间的主要区别是什么?构建性能?运行时性能?命令行选项?许可?
我不是在寻找关于哪个最好的意见,只是对它们差异的基本概述,所以我可以决定哪个最适合我的需要。
您可以在“设置和使用 gccgo ”中查看更多信息:
gccgo,Go 语言的编译器。gccgo 编译器是 GCC 的新前端。
注意 gccgo 不是 gc 编译器
如“ GCC 4.7.1 中的 Gccgo ”(2012 年 7 月)中所述
Go 语言一直是由规范定义的,而不是由实现定义的。Go 团队编写了两种不同的编译器来实现该规范:gc 和 gccgo。
- gc 是原始编译器,go 工具默认使用它。
- Gccgo 是一个不同的实现,具有不同的重点
与 gc 相比,gccgo 编译代码较慢,但支持更强大的优化,因此由 gccgo 构建的 CPU 密集型程序通常会运行得更快。
还:
- gc 编译器仅支持最流行的处理器:x86(32 位和 64 位)和 ARM。
- 然而,Gccgo 支持 GCC 支持的所有处理器。
并非所有这些处理器都经过了 gccgo 的彻底测试,但很多都经过了测试,包括 x86(32 位和 64 位)、SPARC、MIPS、PowerPC 甚至 Alpha。
Gccgo 还在 gc 编译器不支持的操作系统上进行了测试,尤其是 Solaris。如果您从标准 Go 版本安装 go 命令,它已经通过
-compiler
选项支持 gccgogo build -compiler gccgo myprog
:.
简而言之:gccgo:更多优化,更多处理器。
然而,正如OneOfOne ( source ) 所评论的,gccgo 支持的 go 与最新的 go 版本之间经常存在不同步:
gccgo 仅支持最高版本 go v1.2,因此如果您需要 1.3 / 1.4 (tip) 中的任何新内容,则无法使用 gccgo。——</p>
GCC 4.9 版将包含 gccgo 的 Go 1.2(不是 1.3)版本。
GCC 和 Go 项目的发布时间表不一致,这意味着 1.3 将在开发分支中可用,但下一个 GCC 版本 4.10 可能会有 Go 1.4 版本的 gccgo。
twotwotwo在评论中提到了 Brad Fitzpatrick 演示文稿的幻灯片
gccgo 生成非常好的代码
......但缺乏逃逸分析:用许多小分配 + 垃圾杀死性能
...... GC 不精确。对 32 位不好。
twotwotwo 补充说:
另一张幻灯片提到非 gccgo ARM 代码生成很不稳定。
假设它对您的项目来说是一个有趣的选择,可能会在您的目标架构上比较您的用例的二进制文件。
正如peterSO 评论的那样,Go 1.5 now (Q3/Q4 2015) 意味着:
编译器和运行时现在完全用 Go 编写(带有一点汇编程序)。
C 不再参与实现,因此曾经构建发行版所必需的 C 编译器已不复存在。
“Go in Go”幻灯片确实提到:
C没了。
旁注:gccgo 仍然很强劲。
不,
gccgo
出现在 之后gc
。
gc
最初是用 C 语言编写的。它是基于 Ken Thompson 的Plan9 操作系统(Unix 的继承者)的 C 编译器,由同一人设计。gc
被迭代重构,越来越多的自己用 Go 编写。
gccgo
由与 Go 项目无关的 GCC 黑客 Ian Lance Taylor创立。请注意,第一个完全自托管的 Go 编译器实际上是用于 Windows 的专有商业闭源实现,它的名字似乎已经从我的脑海中消失了,就像它从互联网上消失一样。他们声称有一个用 Go 编写的自托管编译器,针对 Windows 的时间
gccgo
还不存在,并且gc
在 Windows 上设置起来非常痛苦。(你基本上必须建立一个完整的 Cygwin 环境,修补源代码并从源代码编译。)然而,在他们成功地推销该产品之前,该公司似乎已经倒闭了。
Hector Chu确实在 2009 年 11 月发布了 Go 的 Windows 端口。
该go-lang.cat-v.org/os-ports
页面还提到了Joe/Joseph Poirier的初始工作。在此页面中:
知情人士是否有机会要求参与生产 Windows 端口的其中一个人( Alex Brainman - Hector Chu - Joseph Poirier)可以制作一个详细说明其构建环境的 wiki 条目?
再加上(在用 Go 编写 Web 应用程序中)!光京(魏广靖)。