在Guido van Rossum(吉多·范罗苏姆)卸任BDFL(“终身仁慈独裁者”)一职半年多之后,Python社区迎来了新的治理新方案:指导委员会模式,而经过投票Guido van Rossum也成为五大指导委员之一,Python之父Guido重回决策层。

BDFL:全称是 Benevolent Dictator For Life(终身仁慈独裁者),该位置被赋予绝对的最终决策权,因为龟叔具有PEP的最终决策权,而反观PHP改进则全部是由社区投票决定,所以被称为”独裁者“;而“仁慈“这一词说明龟叔为人很好,不像linux大佬那样不服就怼,还回回能赢,哈哈!

事件一、龟叔创Python

Guido von Rossum(以下简称:龟叔)是荷兰人,生于1956年1月31日。1982年,Guido从阿姆斯特丹大学获得了数学和计算机硕士学位。

龟叔接触并使用过诸如Pascal、C、 Fortran等语言。这些语言的基本设计原则是让机器能更快运行,因为早期个人电脑配置极低内存可能就一百多kb,所以早期语言很难能实现什么内存管理、垃圾自动回收、面向对象等,那会让你的电脑直接卡死! 但是到了上世纪90年代,计算机得到了快速的发展,硬件的性能越来越好(所以在90年代大量的面向对象语言被开发:Python、Visual Basic、Ruby、Java、JavaScript、PHP),所以Guido希望有一种语言,这种语言能够像C语言那样,能够全面调用计算机的功能接口,又可以像shell那样,可以轻松而简洁的编程。

ABC语言让龟叔看到希望。ABC是由荷兰的数学和计算机研究所开发的。20世纪80年代中旬Guido在该研究所工作,并参与到ABC语言的开发。ABC语言以教学为目的。ABC语言希望让语言变得容易阅读,容易使用,容易记忆,容易学习,并以此来激发人们学习编程的兴趣。
如下面是一段来自Wikipedia的ABC程序,这个程序用于统计文本中出现的词的总数:

HOW TO RETURN words document:
   PUT {} IN collection
   FOR line IN document:
      FOR word IN split line:
         IF word not.in collection:
            INSERT word IN collection
   RETURN collection

HOW TO用于定义一个函数,PUT是赋值,是不是和Python有很多相识之处。

但是因为硬件性能和语言本身存在的缺陷等原因此语言并没有流行起来,而1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本解释程序,作为ABC 语言的一种继承,所以python就被发明了。1991年,第一个用C语言实现的Python解释器公开发行。

事件二、龟叔离职

2018年7月12日,龟叔通过开发者邮件组宣布要“移交权力”,促使他作出此决定的导火索是 PEP 572这个改进提案,该提案获得通过后的三天内龟叔收到了太多的反对意见,龟叔在邮件中有这样一句话:“我从未想到需要为一个 PEP 费上这么大的劲,并发现有这么多人鄙视我的决定”,从这句话可以看出大佬已经心力憔悴了。。。

  • 龟叔离职后接受外媒 InfoWorld采访,其中就聊到这此次退出决策层背后的隐情:https://www.oschina.net/news/98455/guido-van-rossum-resigns
  • 龟叔邮件原文链接:https://mail.python.org/pipermail/python-committers/2018-July/005664.html,以下翻译自google翻译)

PEP:全称是Python Enhancement Proposal(改进提案),社区通过PEP来给 Python 语言建言献策,每个版本你所看到的新特性和一些变化都是通过PEP提案经过社区决策层讨论、投票决议,最终才有我们看到的功能。

而这个引发大佬生气的改进提案PEP 572究竟是个什么功能呢?

PEP 572:新增了赋值表达式:=,这个表达式是不是和赋值符号=很像呢?其实他们的功能都是一样的:给变量赋值,那区别在哪里呢?猪哥给大家举一个简单的栗子:
befor:

i = 3 + 5	# 这个叫赋值语句
if i:
    return i

after:

if (i: =3 + 5):	# : =这个叫赋值表达式
    return i

可以看到新增的赋值表达式使代码更加简洁,而且这真的只是一个轻微的语法变化,不知为何会引发如此大的震荡,可能很多人早就对龟叔大佬不服了吧!

这个改进将在python3.8版本中使用,目前python3.8开发到了alpha 02版本,喜欢尝鲜的朋友可以去官网下载来玩玩:https://www.python.org/downloads/release/python-380a2/

事件三、新的治理方案

随着龟叔的撂蹶子,Python的未来之路牵动了万千开发者的心。没了首领,Python 今后的发展会怎么样?社区将如何运作?谁来领导 Python 这门语言和社区呢?这些问题不得不解决,而用什么样的方式解决,这就需要先由社区讨论并最终决定。

于是,Python 社区共提出了 7 种治理方案,分别是 PEP 8010、PEP 8011、PEP 8012、PEP 8013、PEP 8014、PEP 8015 与 PEP 8016。这些提案都汇总在 PEP 8000 之下,其中最终胜出者,将决定 Python 未来的发展方向和方

2018年12月17号,经过94位核心开发者投票,最终PEP 8016:指导委员会模式当选为新时代的 Python 社区治理方案。

PEP 8016 治理方案采用指导委员会模式,其特点是引导治理的迭代,其中提出了不信任投票,也就是弹劾机制,可将任期内的当权者赶下台;它严格限定了在委员会里,只允许少于 50% 的成员是企业(5 人委员会里最多有 2 个);并且关注到核心开发者的选举/淘汰、如何更新治理提案等问题。PEP 8016 也提出了新的 PEP 流程,目前的 PEP 流程是提案人确定 PEP 的选题方向,提案人负责收集与整合来自整个社区的反馈。然后,相关领域的专家们汇总全部讨论,并开启为期 14 天的审查,之后进行社区投票。如果一个 PEP 很有争议,任何专家成员都可发起动议来拒绝通过它,这需要超过 2/3 的票数。PEP 8016 的 PEP 流程:理事会在必要时可直接地批准/否决 PEP,但最好是设置流程来避免这样做决策,例如,将决策权委派给团队或者 BDFL 代表。

这种治理方案有点和联合国安理会的治理办法类似,同样五个委员,同样具有一票否决权。
投票结果链接:https://civs.cs.cornell.edu/cgi-bin/results.pl?id=E_fe2b74aea628b45

事件四、龟叔当选指导委员

2019 年2 月 4 日,在为期两周的投票后,Python 社区选出了新治理模式下指导委员会的 5 名成员,在17位候选人中龟叔以得票数第一当选!

我们来看看指导委员会的职能:

  • 维护 Python 语言及 CPython 解释器的质量与稳定性
  • 尽可能使做贡献是便利的、包容的与可持续的
  • 巩固核心团队与 Python 软件基金会的关系
  • 为 PEP 建立恰当的决策流程
  • 为贡献者与核心团队寻求共识
  • 当其它所有方法都失败时扮演“最终裁决法庭”的角色
  • 这个治理模式是借鉴自 Django 项目,详细内容参见 PEP-13。

值得一提的是龟叔是自荐成为候选人的,并且是 17 名候选人中最早自荐或被提名的几个人之一,说明大佬还是心系python千千万万的开发者;回忆起同样回归的linux之父,我想这些语言之父对自己发明的语言而言肯定会有一种难以割舍的情怀!

Python未来发展之路

看完整个事件的始末,我有种喜忧参半感觉,忧的是python社区治理方案看似从专制走向民主,但谁又能确认这不会沦为新一轮的决策层斗争的开始,因为此次事件的根本原因在于核心开发意见不一致造成,而增加决策人员的增加,势必会造成更大更多的意见不一致,那时决策层是否会产生更大的矛盾?是否会影响python每一年半一次的发布周期?喜的是龟叔的回归我想对千千万万的Python开发者们无疑是一个巨大的好消息,有种武侠小说里帮主归来的感觉。希望在帮主的带领下Python一统江湖!

参考:
1.https://www.python.org/dev/peps/
2.https://my.oschina.net/editorial-story/blog/2989027

Python之父重回决策层的更多相关文章

  1. Python之父重回决策层,社区未来如何发展?

    春节假期结束了,大家陆续地重回到原来的生活轨道上.假期是一个很好的休息与调节的机会,同时,春节还有辞旧迎新的本意,它是新的轮回的开端. 在 Python 社区里,刚发生了一件大事,同样有开启新纪元的意 ...

  2. PEP 8016-Python之父重回决策层

      PEP 8016-Python之父重回决策层 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 去年,技术社区里还发生了一件大事:Linux 之父 Linus Torvalds 宣 ...

  3. Python 之父的解析器系列之三:生成一个 PEG 解析器

    原题 | Generating a PEG Parser 作者 | Guido van Rossum(Python之父) 译者 | 豌豆花下猫("Python猫"公众号作者) 声明 ...

  4. Python 之父的解析器系列之五:左递归 PEG 语法

    原题 | Left-recursive PEG grammars 作者 | Guido van Rossum(Python之父) 译者 | 豌豆花下猫("Python猫"公众号作者 ...

  5. Python 之父 63 岁才退休,我 23 就中年危机。。

    Java技术栈 www.javastack.cn 优秀的Java技术公众号 Python 之父 Guido van Rossum 在推特公布了自己从 Dropbox 公司离职的消息,并表示已经退休. ...

  6. Python之父Guido在最近一次采访的最后说了啥

    Python之父Guido在最近一次采访的最后说了啥? 在前些天的一次采访中,被问到Python未来发展方向的时候原文在infoworld,咱们可爱的python老爹Guido是这样说的: One t ...

  7. Python 之父谈放弃 Python:我对核心成员们失望至极!

    Python 之父讲述退位原因,以及 Python 的未来将何去何从. ​ 在 Python 社区,Python 的发明者 Guido Van Rossum 被称为 “仁慈的终生独裁者”(BDFL,B ...

  8. Python之父新发文,将替换现有解析器

    花下猫语: Guido van Rossum 是 Python 的创造者,虽然他现在放弃了"终身仁慈独裁者"的职位,但却成为了指导委员会的五位成员之一,其一举一动依然备受瞩目.近日 ...

  9. Python 之父撰文回忆:为什么要创造 pgen 解析器?

    花下猫语: 近日,Python 之父在 Medium 上开通了博客,并发布了一篇关于 PEG 解析器的文章(参见我翻的 全文译文).据我所知,他有自己的博客,为什么还会跑去 Medium 上写文呢?好 ...

随机推荐

  1. 几个大型网站的Feeds(Timeline)设计简单对比

    https://mp.weixin.qq.com/s?__biz=MjM5NzQ3ODAwMQ==&mid=404465806&idx=1&sn=3a68a786138538f ...

  2. 设置firefox每次访问网页时检查所存网页的较新版本

    我们做技术,经常在写页面的时候需要多次刷新测试,可是浏览器都有自己的缓存机制,一般CSS和图片都会被缓存在本地,这样我们修改 的CSS就看不到效果了,每次都去清空缓存,再刷新看效果,这样操作太麻烦了. ...

  3. git添加本地的项目到git远程管理仓库

    目标:将本地存在的项目添加到git远程仓库管理 步骤: 1. 需要一个git远程仓库管理地址 例如:https://github.com/xingfupeng/test.git git@github. ...

  4. Chatbot思考录

    人工分词产生不一致性的原因主要在于人们对词的颗粒度的认知问题.在汉语里,词是表达意最基本的意思,再小意思就变了.在机器翻译中会有一种颗粒度比另外一种颗粒度更好的情况,颗粒度大的翻译效果好. 为了解决词 ...

  5. ArcCore重构-头文件引用问题的初步解决

    基于官方arc-stable-9c57d86f66be,AUTOSAR版本3.1.5   基本问题 1. 头文件引用混乱,所有头文件通过从搜索路径(-I)中引用,存在名称污染问题,需加入路径信息:   ...

  6. String 类的函数实现

    #include<iostream> //#include<string> using namespace std; class Strings { public: Strin ...

  7. 软工第五次作业——Python效能分析之四则运算生成器

    Github项目地址: https://github.com/JtvDeemo/elementary-arithmetic PSP PSP2.1 Personal Software Process S ...

  8. 第四章 MySQL数据类型和运算符

    5.1 MySQL数据类型介绍 一.数据类型简介 (1) 数据表由多列字段构成,每一个字段指定了不同的数据类型,指定了数据类型之后,也就决定了向字段插入的数据内容 (2) 不同的数据类型也决定了 My ...

  9. 关于office在卸载了某一应用之后无法试图使用的功能所在的网络位置

    我出现这个问题是在卸载了某一个微软的办公软件之后,所有的办公软件都会产生这个问题. 处理的方法是将之前的安装包解压,然后找到所出现的msi文件,点击确定就ok了. 所以说,安装文件最好还是放在一个地方 ...

  10. java 字符常量池

    一.题目: 问题:String str = new String(“hello”),“hello”在内存中是怎么分配的?    答案是:堆,字符串常量区. Java中的字符串常量池和JVM运行时数据区 ...