Go 是社区驱动吗?哪种模式更好

这篇文章讨论了Go语言是否真正由社区驱动,以及Google在Go发展中扮演的角色。作者引用ChrisSiebenmann的观点,指出Go的核心团队在决定语言发展方向上占据主导地位,而社区的影响有限。文中还提到Go与其他社区驱动项目如C++的对比,以及企业对开源项目所有权的复杂性。
摘要由CSDN通过智能技术生成

大家好,我是煎鱼。

上一篇给大家分享了《Go 是 Google 的语言?核心成员的内部视角》,增加了一些 Go 核心团队内部视角思考。

本文继续基于对两篇文章的前因后果的补充,基于《Is Golang truly community driven and does it really matter?》,煎鱼对内容有所调整和补充。

快速背景

几年前在 Hacker News 社区,针对 Go 的一个问题引发了激烈的辩论:“Go 是 Google 的语言,而不是社区的”。

这个讨论最初是由在多伦多大学计算机科学系工作的 Chris Siebenmann(下称:他)发起的。

fc86218448beebe6ca74d9de14f65280.png

他在博客文章中写道:“Go 有社区贡献,但它不是一个社区项目。它是 Google 的项目。”

为什么 Go 不是社区的语言

Chris 明确指出,社区的声音对于 Go 的发展并不重要,我们必须接受这一点。他认为:Google 是 Go 社区贡献的守门人;只有 Google 独自决定什么是被接受的,什么不被接受

如果开发者想要一些重要的特性被接受进 Go,与其与社区建立共识,远不如说服 Go 核心团队重要。

他引用了一个例子:Google 的 Go 核心团队成员之一(指的是现在的 Go 核心团队负责人 rsc)放弃了社区一直在努力开发的 Go 依赖管理系统(指的是 dep 等),并引入了一个新的、相对激进的不同模型,也就是现在的 Go Module。

注:这里讲的是好多年前,Go 还没有官方的模块管理。社区自发的有 godep 等各种工具。一开始谈好要基于某一个社区工具继续开发转成官方的。结果后面 rsc 等觉得不好用,最终自研了官方的模块管理,直接一纸之下取代了。

期望和对比管理方式

Chris 期望的是:Go 核心团队要关心社区,并希望他们参与建设,但要限制在一定的程度的参与度。他希望 Go 核心团队能坦率地诚实地说明情况,而不是假装并误导人们。

他进一步补充说:“只有当 Go 核心团队成员开始离开 Google,并尝试继续积极参与决定 Go 的方向时,我们才能确定 Go 是一个社区驱动的语言。”

他将 Go 与 C++ 进行了比较,称后者是一个真正的社区驱动语言。

b17f0afb9eec4f8bef537d5fd2d2c39a.png

他说 C++ 有多个主要实现,这些都是真正的社区项目,C++ 的方向由一个开放标准委员会决定,成员分布相对分散。

2fc6b6ce1f64daf439d6969320cf12af.png

社区驱动还是企业所有的区别

开发人员中一直流传着这样一种观点:一些开源编程项目只是主要由一家公司驱动的商业项目。

我们看一下业内的顶级开源项目,它们中的大多数都有某种企业合作、支持,甚至直接的资金援助。

例如:

  • 苹果的 Swift;

  • 甲骨文的 Java、MySQL;

  • 微软的 Typescript;

  • 谷歌的 Kotlin、Go、Android、MongoDB、Elasticsearch;

仅举几例。这就引出了一个问题:企业对开源项目的所有权到底意味着什么?

仁慈的独裁有两种结果。

如果某个项目基于社区建议进行修改,而修改又是个坏主意,企业团队可以进行干预,阻止修改。

但另一方面,反过来看,即使核心团队的少数成员不同意,也可以阻止社区的好想法得到实施。

社区观点

Chris 的帖子在 Hacker News 上引起了开发者的广泛关注,他们既支持也反对提出的观点。

以下是摘取的有一定观点的评论:

  • 网友 A:拥有一个社区并与它合作很重要,但尤其是对于编程语言来说,必须有一个清晰的概念,哪些特性应该实现,哪些不应该——仅仅为了使社区感觉良好而接受社区贡献将是错误的方式。

  • 网友 B:许多人喜欢 Go 是因为它是一种有观点的语言。我不确定一个社区运行的语言会创造出像那样的东西,因为意见太多。许多人声称代表社区,但不是那些不分享他们观点的社区。没有明确的领导者,我担心技术方向和品味将变成政治,这似乎更不确定和风险。

总结

整体看来,似乎没有完美的答案。因为几乎所有所谓的成功的顶级项目,背后都一定有各大公司的影子,只是或多或少罢了。

Go 这一门编程语言的模式,可能也是一种比较另类的成长方式。现在被抨击的点,有些也是直接太狠直接推翻社区导致的。

另外结合 Go 的发展历程来看,如果 Go 不是诞生于 Google 团队内部,可能发展和当红的也不会那么顺利,与云原生的结合可能也会没有那么深。

推荐阅读

关注和加煎鱼微信,

一手消息和知识,拉你进技术交流群👇

6e2b19f84450c56f92e457fa04dd24b9.jpeg

a5fbf5feef8956c3731883e3493476bb.png

你好,我是煎鱼,出版过 Go 畅销书《Go 语言编程之旅》,再到获得 GOP(Go 领域最有观点专家)荣誉,点击蓝字查看我的出书之路

日常分享高质量文章,输出 Go 面试、工作经验、架构设计,加微信拉读者交流群,和大家交流!

  • 21
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值