102

两种流行的 Go 编译器“gc”和“gccgo”之间的主要区别是什么?构建性能?运行时性能?命令行选项?许可?

我不是在寻找关于哪个最好的意见,只是对它们差异的基本概述,所以我可以决定哪个最适合我的需要。

4

1 回答 1

125

您可以在“设置和使用 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选项支持 gccgo go 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 仍然很强劲。


Berkant在评论中询问是否gccgogc自举的。

Jörg W Mittag回答:

不,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 应用程序中!光京(魏广靖)

于 2014-09-12T15:14:42.587 回答