谷歌Fuchsia操作系统未选择Go作为终端开发语言,我们应如何理解?

发表时间: 2020-02-27 11:06

昨天 Go 圈被这条新闻刷屏了(当然还有 Go1.14 发布):

谷歌新一代开源操作系统 Fuchsia 的开发者网站上公布了一份 Fuchsia 编辑语言策略,文档描述了 C、C++、Dart、Rust 与 Go 的优劣势,并明确指定了其中哪些语言将会在 Fuchsia 开发生态中得到怎样程度的支持。

该策略文档描述了 Fuchsia 项目在 Fuchsia Platform Source Tree(Fuchsia 平台源码树)和供终端开发者在这之外构建 Fuchsia 开发目标设备软件时使用和支持的编程语言。注意谷歌公布的是终端开发语言,什么意思?即对终端开发者的支持,意味着 Fuchsia SDK 需要包含可帮助他们为 Fuchsia 开发软件的工具和库,包括 FIDL(Fuchsia Interface definition language,Fuchsia 接口定义语言)特定语言后端与支持库等。(这里的 end-developers 我认为是 Fuchsia 的应用软件开发人员)



语言对比、评价

可见什么 Go 要退出,Go 大败,Go 不行了之类的,真的是没啥意义。谷歌这篇文章说的很清楚,也很清楚的对比了 C、C++、Dart、Rust、Go 这 5 门语言的优缺点,看看谷歌对它们的对比:

C

优点:

  • C 是一种广泛使用的语言。该语言具有易于理解的特性,已在很长一段时间内保持稳定,并且过去已用于构建类似的系统。该语言具有成熟的工具链和相关的开发人员工具
  • C 具有稳定的 ABI,它使 Fuchsia SDK 包含预编译的二进制文件,供最终开发人员重新使用;
  • 许多语言可以使用外部函数接口与 C 互操作。支持 C 可使最终开发人员更轻松地将这些语言与 Fuchsia 集成在一起;
  • 我们目前的终端开发人员已经在使用该语言。

缺点:

  • 对异步编程的支持很弱;
  • 用该语言编写的程序通常会由于缺乏内存安全性而导致安全漏洞。
  • 用该语言编写的程序通常包含资源泄漏,因为该语言不提供自动释放资源的功能。
  • 与 C++ 相比,类型安全性较弱。简单地将某些 C 代码重新编译为 C++通常会导致编译器错误,这些错误会掩盖代码中的潜在错误。

最终决定:

  • 支持终端开发人员使用 C 语言,这里显示了支持哪个版本 https://fuchsia.googlesource.com/fuchsia/+/refs/heads/master/docs/concepts/api/c.md#Language-versions。
  • 在 Fuchsia 平台源代码树中,不鼓励使用 C 开发新功能。
  • 允许在以下情况下,在 Fuchsia 平台源代码树中使用 C:
    • 低级系统编程,包括内核中的编程。
    • 定义共享库和其他系统组件的 ABI 稳定接口。

C++

优点:

  • 目前许多终端开发人员都在广泛使用 C++。
  • Fuchsia 平台源代码树广泛使用 C++。
  • C++是一种广泛使用的语言。语言本身易于理解(译注:这个大家认可吗?),经过长时间的沉淀非常稳定,并且过去已用于构建类似的系统。C++具有成熟的工具链和相关的开发人员工具。

缺点:

  • 对异步编程的支持很弱。
  • 用 C++语言编写的程序常常会因为语言缺乏内存安全性而导致安全漏洞。

最终决定:

  • 支持终端开发人员使用 C++。
  • 允许在 Fuchsia 平台源代码树中使用 C++。

Dart

优点:

  • 目前许多终端开发人员都在使用 Dart。
  • Fuchsia 的大部分用户界面都是使用 Flutter 构建的,而 Flutter 使用的是 Dart。
  • 可以使用线性流程的代码编写异步程序。
  • 使用 Dart 编程的生产力很高。
  • Fuchsia 项目有机会影响 Dart 语言的发展。
  • Dart 语言提供了内存安全保证,降低了使用该语言开发的软件存在安全漏洞的风险。

缺点:

  • Dart 语言使用垃圾回收来管理内存,占用的资源比其他内存管理技术更多。
  • Dart 语言的运行时环境很大。
  • 工具链迫使我们必须在可执行文件大小、性能和启动延迟之间进行权衡,这比其他语言的工具链造成的权衡更糟。

最终决定:

  • 支持 Dart,主要供非驱动程序的终端开发人员使用。
  • 在 Fuchsia 平台源代码树中,允许使用 Dart 开发用户界面和非常驻程序。

Rust

优点:

  • Fuchsia 平台源代码树在使用 Rust 方面有很多积极的实现经验。
  • Rust 提供了内存安全保证,降低了使用该语言开发的软件存在安全漏洞的风险。
  • 可以使用线性流程的代码编写异步程序。
  • Fuchsia 项目有机会影响 Rust 语言的发展。

缺点:

  • Rust 不是一种广泛使用的语言。语言的特性尚未得到很好地理解,该语言选择了不寻常的语言设计点(例如,借用检查器),而且历史相对较短。
  • 目前我们的终端开发人员都没有使用 Rust。

最终决定:

  • 不支持终端开发人员使用 Rust。
  • 允许在 Fuchsia 平台源代码树中使用 Rust,但以下情况除外:
    • kernel:Zircon 内核是使用一组受限制的技术构建的,这些技术在建立生产操作系统方面有良好的记录。

Go

优点:

  • Go 是 Google 内部广泛使用的语言。
  • gVisor 已使用该语言实现了网络堆栈,并且该网络堆栈已与 Fuchsia 集成在一起。
  • 使用 Go 语言编程的生产力很高。
  • Fuchsia 项目有机会影响 Go 语言的发展。
  • Go 语言提供了内存安全保证,降低了使用该语言开发的软件存在安全漏洞的风险。
  • Go 语言有具有广泛的库生态系统,对 Fuchsia 非常实用。

缺点:

  • Go 语言使用垃圾回收来管理内存,占用的资源比其他内存管理技术更多。
  • Go 语言的运行时环境很大。
  • Fuchsia 平台源代码树在使用 Go 方面具有负面的实现经验。在 Fuchsia 项目,用 Go 构建的系统组件占用的内存和内核资源比 C++或 Rust 等更多。
  • 工具链会产生较大二进制文件。

最终选择:

  • 不支持终端开发人员使用 Go,但以下情况除外:- 网络栈。将网络栈迁移到另一种语言上需要大量投资。如果时间允许,我们应该将网络栈迁移到批准的语言。
  • 其他在 Fuchsia 中使用 Go 语言构建的目标设备上的生产软件都必须迁移到批准的语言。

如何正确看待这个决定

首先,对于大部分人来说,关注的是终端开发人员的编程语言支持,毕竟 Fuchsia 平台源码树只有少数人会参与其中。

其次,要知道,Dart 也是谷歌的语言,Fuchsia 公开之初就支持 Dart,文中也说了,Flutter 使用的 Dart,所以支持 Dart 是显而易见的,甚至 Dart 2.0 是专门为它们优化设计的;Dart 最初是为了替代 JavaScript,可见它一开始就更适合做终端开发;

第三,谷歌说了,他们内部在广泛使用 Go,可见并不是谷歌要抛弃 Go,任何语言都有其适用场景,不能因为 Go 是自己的,就一定非得支持,得适合,这是不是说明谷歌这个公司靠谱?!

最后,谷歌对 Fuchsia 的定位是开发一个嵌入式操作系统,这个系统最终有多大的市场,一切还未可知,不能因为它不支持 Go,就说 Go 大败。

最最后,我建议大家多关注下文中说的 Go 的优点,而缺点,更多是对于嵌入式系统来说的“缺点”,其他场景可能是优点。

Go 的优点:

  • Go 是 Google 内部广泛使用的语言。
  • gVisor 已使用该语言实现了网络栈,并且已与 Fuchsia 集成在一起。
  • 使用 Go 语言编程的生产力很高。
  • Fuchsia 项目有机会影响 Go 语言的发展。
  • Go 语言提供了内存安全保证,降低了使用该语言开发的软件存在安全漏洞的风险。
  • Go 语言有具有广泛的库生态系统,对 Fuchsia 非常实用。

参考

1、
https://fuchsia.googlesource.com/fuchsia/+
/refs/heads/master/docs/project/policy/programming_languages.md

2、
https://www.oschina.net/news/113639/fuchsia-programming-language-policy

推荐阅读

  • Go1.14 发布了,着重在性能提升上发力