在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. 微信小程序中自定义函数的学习使用

    新手,最近在给学校搞个党费计算器.需要自己定义函数来实现某个功能. 1.无参函数: 函数都是写在js文件里面的. Page({ data:{ income1:'0', }, cal:function( ...

  2. udp客户端收发数据流程

    1.创建客户端socket开始进行通讯.2.这时服务端应该先启动,并在知道服务端的ip以及端口号的时候才能进行通讯.3.本地不需要绑定ip以及端口号,在用此套接字对象发送消息的时候会自动分配活动端口( ...

  3. 运算符优先级--C

    优先口决 括号成员第一; //括号运算符[]() 成员运算符. -> 全体单目第二; //所有的单目运算符比如++ -- +(正) -(负) 指针运算*& 乘除余三,加减四; //这个& ...

  4. python爬虫人门(10)Scrapy框架之Downloader Middlewares

    设置下载中间件(Downloader Middlewares) 下载中间件是处于引擎(crawler.engine)和下载器(crawler.engine.download())之间的一层组件,可以有 ...

  5. day07

    放完了愚人节的假期后就忘记更新了,这样不好,学习的态度也有点懒散了,需要调整过来,这几天在做一个退款流程,想好了建表.逻辑设计和需求分析,然后就是写具体的代码了,有些东西还是要多学习,不然书到用时方恨 ...

  6. ubuntu18.04安装搜狗拼音

    1.下载好搜狗安装包http://pinyin.sogou.com/linux/ ,注意位数! 2.打开终端安装依赖    sudo apt install libfcitx-qt0 3.提取下载好的 ...

  7. scrapy中 Mongo的存储

    import pymongo MONGO_HOST = 'localhost' MONGO_PORT = 27017 MONGO_DB = 'today' MONGO_COLL = 'mm' clas ...

  8. codeforces 983B XOR-pyramid

    题意: 定义一个函数f(a): 给出一个数组a,有q个询问,每次询问回答在l到r的区间内,连续子串的f函数的最大值. 思路: 画图,来自codeforces SheepRanger 由此图可知,f(l ...

  9. Spring Boot使用RestTemplate消费REST服务的几个问题记录

    我们可以通过Spring Boot快速开发REST接口,同时也可能需要在实现接口的过程中,通过Spring Boot调用内外部REST接口完成业务逻辑. 在Spring Boot中,调用REST Ap ...

  10. 并发库应用之十 & 多线程数据交换Exchanger应用

    申明:用大白话来说就是用于实现两个人之间的数据交换,每个人在完成一定的事务后想与对方交换数据,第一个先拿出数据的人会一直等待第二个人,直到第二个人拿着数据到来时,才能彼此交换数据. java.util ...