Larry Wall,Perl教父访谈
看看Perl的创造者,看看Perl的新进展. 我和Perl脚本语言的创造者,Larry Wall(拉里沃尔,),在3月1号通过 电子邮件进行了一次"交谈".Larry显得非常健谈,你一定会觉得这次 交谈既有趣又使人受益.我是这样感觉的.
Marjorie(马乔里,记者,以下简称马): 开始的时候,是什么让你决定开发Perl的?
Larry(拉里,Perl的创造者,以下简称拉): 这要看你的"开始的时候" 是指什么样的"开始". 就象摩西所说:"开始时,上帝创造了
天空和大地." 我并不是完全在说笑.每个人都有他在意(或 不在意)的对圣经的阐释方法,而我认为宇宙万物就是激发 我们想要成为一
个创造者的最大的灵感.我也已经努力地要 把这样一种整体的思想加入到Perl中间去,有些已经获得了 实现. 要是以传记体的开始来
讲,我的父亲是牧师,我的爷爷也是牧 师,我的很多祖先也是牧师.我的妻子总是喜欢说传教士是智 慧的种子(我猜她是在奉承我).不过
也有可能吧,我确实继承 了还算像样的脑组织结构的基因.另外我还继承了一些思想 和技能,有些思想和技能已经融入到Perl文化当中
了.比如,认 为你能改变世界的思想;比如,认为别人很重要的思想;比如, 对于交流的热爱,包括花言巧语的理解,更别说对语言学的关
注了.再比如,对于文字重要性的认识;对于将所有事物与其他 事物进行联系的渴望;对于建设的狂热,对于毁坏的厌恶.当然 还有一点
,那就是真正衡量财富的方法不是看你积聚了多少,而 是看你与别人分享了多少. 最直接的诱因是我遇到了一个问题,我手头的工具都
无法解决它. 或者说,都不能轻易得解决它.就象使徒保罗所说"任何事都是有 可能的,但并不全都是有利的."我应该能够用awk和
shell解决我 的问题,但幸运的是程序员最重要的三个美德在我身上储量丰富, 它们是:懒惰,急躁和傲慢.我太懒了,如果用awk来做的
话需要做 大量的工作,这是无法忍受的.我太急躁了,awk做起来很慢,我可 等不及.然后,我的傲慢使我认为自己可以做的更好一些.
当然,真正要写出Perl这样的东西需要做大量艰苦的工作,也需要 耐心甚至谦卑.如果我仅仅是为了我自己,可能是不会下这么大的 功
夫的.然而,我知道,其他的人也会来使用Perl,不仅仅只有我一 个人而已,所以我的"懒惰曲线"是结合整个社区来绘制的.这样看来 我
的懒惰就是代理性质的懒惰咯.呵呵.
马: 哦,回答的非常全面.必须承认,我本来没有期望你能从宇宙的起源说起:-) 那么,为什么用Perl这个名字呢?
拉: 我希望起一个短一点的有正面意义的名字.(比如,我绝对不会把一个语言 叫作"Scheme"或是"Python").实际上我查阅了字典中
所有三个或是 四个字母的单词,最后却一个也没有用.我也曾想过用我妻子的名字 ,Gloria,来命名它,但与家庭态度相左.最后我选中
了"Pearl",作为 Practical Extraction and Report Language(实用摘录和报告语言) 的缩写.那时,字母"a"还在名字当中.但是
我听到有传闻说有个朦胧 绘画语言也叫作"pearl",就把它缩短为"Perl"了.(当我给这个语言新 的诠释的时候,名称中的"a"也就真的
消失了,可以把"Perl"理解为: Pathologically Eclectic Rubbish Lister病态折衷垃圾列表器 (译者:晕,怪不得这种解释不常见
到,太抽象了点:-!)). 另一个关于"Perl"这个名称的珍闻是,刚开始时"Perl"中间的"p"是小写 的.那时UNIX还只能支持小写字母.实
际上,你可以把它叫作反小写系统. 就象在网上发贴的人最初所有的东西都是小写的,后来它们发现适当的 使用大写可以使得交流更加
的方便.对Perl来说,当Perl4发布之时我们觉得 有必要区分"perl"程序和"Perl"语言.如果你找出第一版骆驼书,你可以 看到标题是
Programming perl,p是小写的.而现在,标题是Programming Perl.
马: 嗯,Perl现在完美了吗,你还会进一步的开发它吗?
拉: 嗯,这两者并不是互斥的. 看看Linux. :-) 实际上,Perl从来没有设计的很完美.设计的时候我们就打算使它适合进 一步的发展
,具有更强的适应性.从生物学角度来讲,世界上没有完美的 生命体.最多你只能说一个生命体对其所处的环境适应的好些或是差些. 实
际上,生物学家已经认识到任何对于一个环境来说似乎是"完美"的生命体 当环境发生变化的时候就有灭绝的危险.超特定性几乎与生态
龛位同义. 我们说的并不只是恐龙,还有快速蜗牛和印度豹,还有巴西的一种甲虫-- 当然还有Visual Basic. 我们已经看到很多超特
定性有机体的死亡了,在计算机世界中,这包括: Lisp机器,Ada芯片和很多所谓的第四代语言.任何用汇编语言为废弃的 系统编制的程
序如今也都被废弃了.同样的,任何把自己的命运与单一 操作系统捆绑在一起的程序也会随着操作系统的消亡而消亡.我不知道
Windows在沉没之前还能够经受几颗鱼雷的轰击,但是当它沉没的时候, 一大批仅适用于这个操作系统的程序将随其一起沉没.明显的
,由于开放源码 运动,Linux不存在这样的问题. 不管怎么说,让我们回到Perl上来.从一开始,Perl就是为改变而设计的. 这中间包括
了某些折衷.如果以和我不同的观点来看的话,这些折衷可能 并不是最好的处理方法.比如,为了在将来给Perl增加关键词的时候不会
破坏已有的老程序,我在变量名上给它们使用了不同的命名空间.即变量 名和关键字必须是要用标记明显区分开的.我选择了标记变量
,一个是因为 这样可以方便的使用变量在字符串中的内插,另一个原因是在BASIC语言 中有标记变量的先例.在某些环境下这可能是无
法接受的,比如某些顽固 的纯化论者会说,加入标记会使Perl变得很难看,而且太象BASIC.或许吧. 那又怎么样?这是一种有意的折衷
,目的是为了Perl可以更为有用.从这方面 来讲,Perl可能不是很符合计算机科学家的定位,但是它适合这个世界. 对于这个折衷,我从
来没有觉得遗憾. 当然,第一印象之后,还是有些东西会得到计算机科学家的喜欢的,比如变量 的作用域和closures.因此大体上,如果
这些科学家能够强捏住他们的鼻子 把Perl奶酪放到他们的嘴里尝一尝的话,那么他们会发现还是可以一吃的. 更重要的,Perl5使用了
一种扩展系统,它有些类似Linux的模块系统,允许 连续的开发,而不需要改变核心语言.即,你可以开发特定功能的Perl模块 如果这个
模块非常流行,常用的话,我们会考虑把它加入到Perl核心中去. 这并不是说我们不会改变核心了.最近我们还加入了对多线程和
Unicode的支持. 有趣的是,虽然我们确实是在修改核心,我们还是使得它看起来就象是在做一 个扩展模块.实际上,如果你要使用新的
核心的特性,那你必须要首先声明. 这正是我们使得Perl几乎可以100%兼容老版本Perl脚本的秘诀.大多数Perl1 的脚本可以不用更改
的运行于Perl5之下.一个附带的好处是,对于特性的声明 使得依赖性在编译时是可见的,所以程序不会在运行时因为缺少某个特性而退
出. 这与shell编程形成了鲜明的对比,在那里,直到执行的时候这些问题才会暴露 出来.
马: 有没有进一步的Perl开发计划?
拉: 我要是比自己再聪明一些,大概就能预见到了.不过我的智慧只能是知道我还没有 聪明 到那样的程度,正因为如此我把可扩展性放
到了Perl的首要位置. 说到这个,我可以告诉你一些我希望实现的特性. 首先,如果要来处理文本,Perl是首选.Perl一直就是一个文本
处理语言,虽然很早 以前它就已经不仅仅局限于文本处理了.由于这个缘故,Perl就成为CGI编程的首选, 因为在提取和组合文本方面
Perl非常拿手. 其次,我希望Perl可以把这样那样的东西黏结到一起.我们并不是黏结积木,我们 的目的是把原来并不同类的东西黏结
到一起.作为一个胶水语言,Perl既适合于 修补裂缝,也适合于填充壕沟.Perl对空隙极为熟悉.典型的CGI脚本或是mod_perl
servlet可以把数据库和网络黏结到一起.当一个空隙消失之后,又会产生其它空隙. 第三,我希望可以给失去特权的人以特权.我们开
玩笑说准备把多出来的饭菜送给 饥饿的非洲人,实际上,在美国之外,有非常多的程序员,他们没有足够的钱用来 购买操作系统或是软
件.中国最近一次就从某出版社(我为其工作)订购了200,000 本英特网书籍.这仅仅只是开始而已.也正因为如此去年我把对Unicode的
支持加入 到Perl中去.当然,文本处理也涉及到Unicode. 说了这么多,其实它们基本上和下一步的开发计划无关,因为这些天以来我基
本上 已经很少参与开发了.Perl社区的工作已经超过我很多数量级了,他们才是真正的 使Perl成为真正的脚本语言的人.我只是待在
一边偶尔为他们欢呼罢了.我现在就 要为他们欢呼.啦啦啦! :-)
马: Perl到底是在哪些方面优于其它的脚本语言的,比如Python和Eiffel?
拉: 对于脚本语言来讲,Perl是独特的,而且在所有的计算机语言中,Perl也是非常独 特的.它 是唯一的一个有意识的并且明确的被设
计为后现代化的计算机语言.而其它的语言都还不同程度的坚持着他们的现代化特性.事情虽然是这样,我却很少使用后现代化 来描述
Perl,因为很多人并不能真正理解后现代主义,虽然他们已经处于后现代化之中.事实是,美国文化已经完全进入后现代化了,不仅是音乐
和文学,还包括时尚, 建筑以及所有的与文化沾边的领域. 现代化是基于某种傲慢之上的,把创意置于一切之上的文化的有色眼镜,它的
设计者 认为他们认为很好的东西,全世界都应该喜欢.即是说,如果某件事值得做,那就应该 把所有其它可能的途径都推到一边而仅留
它一个.看看在Lisp中对圆括号的使用,以及 Python中对空格的使用吧.还有对对象的强制使用,这包括很多语言,其中就有Java. 所有
这些都是"为了用户考虑"而限制了用户的自由.它们其实就是阻碍自由思想的翻版.1970年代的时尚警察已经离我们远去了,但是很多程
序员依然是网络警察的奴隶 . 恰恰相反,后现代主义允许人们对任何艺术品从个人的或是不同文化的背景给出诠释 . 无论怎么说都是
你自己的事情.Perl的口号即来源于此,那就是:"条条大路通罗马".Perl 之所以在你做任何事时都给你许多不同的可以使用的方法的
原因是:我确信程序员们都希望自己是具有创造性的,他们可以有很多不同的理由想要写出他们自己的特别的代码. 你想要做什么是你
自己的事情,不是我应该考虑的.我要做的就是给你油漆--而你绘制 你的图画.
马: 谁在使用Perl,他们怎么使用它?
拉: 两年前,我在一次商业展会中遇到一个人.他和另一个人在经过我面前的时候,他 正给那人介绍 国家安全局的有关情况,他说他用
Perl写了一个过滤器.我于是问他,我可不可以告诉 别人 国家安全局使用Perl.他当时的回答是:"难道有谁不用吗?"所以现在我不会
说国安局 用Perl. 我只是告诉大家国安局的人认为大家都在用Perl.我想大家应该知道这个. 有趣的是,正是这个人中止了那个使用
到perl的项目.当我告诉他,Perl可能是那个项 目最大 的受益者时,他觉得很开心. 说到大家用Perl做什么,可以说是做什么的都有
.几年前当我听说Perl在华尔街使用非 常广泛的 时候,着实吃了一惊.当时他们说:"每个桌子上都有一本Perl书".不过,考虑到市场分
析需要 他们不断的修正他们的模型,他们还需要扫描那些可能与他们在市场中的位置相关的 新闻信息 的话,就会觉得合情合理了.他
们需要的正是快速原型和文本处理. 很多人把Perl和CGI脚本联系在一起,其实那主要是由Apache下的mod_perl servlets 完成的.
Perl多是用于那些客户端的机器人和蜘蛛,它们搜索网络并在形形色色的数据库中建 立链接. 不过,这并不是全部.如果你曾经受到垃
圾邮件的困扰(有谁没有过?),那么几乎可以肯 定,你的 邮件地址被某个Perl脚本从网络上搜集到了.垃圾邮件本身也很有可能是由
Perl脚本 送出的. 有人可能说Perl是滥用网络的首选.但同时也会有人以此为傲. 这仅仅是Perl用途的一鳞半爪而已.如果不考虑民
意测验或调查也不考虑美国人口调 查局, 那么最好的了解Perl用途的方法就是查看Comprehensive Perl Archive Network (CPAN
) 站点上的800个或是经常使用的模块.如果你把这些模块都看一遍,你会发现,Perl几乎 与世界 上所有事物都有联系.稍微动动脑筋
,你会发现Perl之所以与世界上所有的事物都有联 系, 并不是因为Perl能够与所有这些事物如何如何,而是因为Perl可以把世界上的
所有事 物联系在 一起. 组合学是令人惊讶的.Perl杂志的第一期(不要与Linux杂志混淆)有一篇文章, 标题是 "Perl是如何拯救了人
类基因组计划".文中说明了世界各地不同的基因组实验室使用 了不同的 数据库,其中的数据格式也是千差万别,而Perl如何将这些数
据处理成统一的数据.
马: 我们收到ActiveState Tool公司的一份产品声明,它说: ``PerlDirect 提供对Perl的如下特性的可靠的,稳定的,支持和责任:
Perl的 可用的高质量的分发包,以及常用扩展;建议和支持;Y2K测试组件; 每周一次的Perl警告信息. PerlDirect提供给您直接支持
一个引导开源运动 的组织的机会.年捐助额应当不低于12,000美元.'' 你和这家公司熟吗?我觉得他们提供的这个机会非常有趣.这有
什么意义吗?
拉: 听起来好像是和我签约的支持.我相信即使是Richard Stallman也会承 认技术支持是通过自由软件盈利的有效方式. 我和
ActiveState没有直接的联系,不过我跟他们合作过,我想他们解决的问题 远比他们引起的问题要多得多.你得了解,他们的市场是
Windows,在那里他们 收取报酬帮用户做事是很好的事情,因为那是唯一不会使用户们疑惑的方式. Linux用户当然要聪明一些,不过他
们还是不够聪明,没有认识到Windows完全 是一种不同的文化,而Perl作为一种后现代化语言对环境是非常敏感的,因此 在那样一种环
境下看起来会大不相同.
马: 噢,我的本意并不是说他们不诚实--只是好奇想知道你到底知不知道这件事. 你对开放源代码运动的看法怎样?你认为它将会变成
长期存在,还是只是一时流行?
拉: 我的大脑一定是连接性很强的,因为我认为你所说的两方面都是正确的.而且 它们同时也都是不对的. ;-) 到目前为止,开源运动
已经经历了20年的发展了,我们怎么能说它将变成什么什么? 我们仅仅要向大家显示开源也曾经产生了大量优秀的代码程序.另一方面
,我们想 更进一步,希望更多的人认识到这是一种有效的开发模式,对很多不同种类的,以前 都是以封闭模式开发的软件也是适用的.
不过,当然,它也是一时流行--就象我们已有的其它一时流行的东西一样,比如 自由语法,结构化程序设计以及最近的面向对象. 你得了
解的是,对一时流行的东西,人们通常会有两种对待的方法.这有些象启示录中 把绵羊和山羊分开一样.有些一时流行的东西,流行过去
之后就会从此消失,但是另外 一些一时流行的东西会由流行转为平淡,通常在这之前都会经过一个狂热期.比如 自由语法,结构化程序
设计和面向对象等,它们都是由一时流行转为平淡,但是并没有 消失.那些流行之后即消失的东西,通常不是来源于历史,而是来源于某
些人的希望 (通常是市场人士).以此来判断的话,开源应该会由一时流行转为普通应用,因为它 其实已经是普通应用了. 以我来看,开
源运动正是我们正在成长的后现代化文化的又一个展示.相反的,所谓商 业 机密的提法只是之前的创意无价的思想的翻版.我们以前经
常说代码重用服务,可是这 么多年来,只有当开源出现之后,代码重用服务才得以实现.后现代化程序员认为重用 好代码不必考虑它是
原创还是相反.这与自豪无关.后现代化主义者应该是一个剽窃者 , 剽窃一切他(她)认为精彩的东西.
马: 要是什么东西都开源的话,程序员要靠什么生活呢?
拉: 和许多其他开源的支持者不同,我不认为任何东西都会开源. 我所持的是目前也在逐渐得到更多认同的观点,那就是那些具有 很
大规模的基础性的东西需要开源,就象美国政府逐渐认识到州 际公路应该是不收费的一样.另一方面,我不会期望城市中的停车 场会免
费,除非那个市府特别开明.因此如果拿Windows和Word来 比较,我更希望Windows能够开源. 有一种说法,我们可以有很多方法通过开
源来谋生,这就好像我们 有很多方法通过开放的科学来谋生一样.不过,我认为这里正是开源 需要努力开发的一个方向.科学在开始时
,只是富人的爱好,只是当 它进入到教育学院之中以后才逐渐发展成今天为我们所熟悉的形式. 开源还没有开始这一步,或者更确切的
说,开始了,但是各个教育 院校却把目标设定在赚钱上了.我希望有更多的地方能向UC Berkeley 学习.
马: 那么,你靠什么谋生呢?
拉: 开始时,我和其他人一样,一边编程一边做系统管理的工作,同 时我还开发自由软件.之后,我写了一本书然后就有了版税.那本书
很畅销,它使得我和出版商O'Reilly & Associates都赚了很多钱,可能赚的 比我还多.当然,那些钱他们还要用来支付其他人的报酬
,总的来说 是差不多的. 不管怎么说,三年前我和Tim O'Reilly都认识到,对Perl有利的事情dv O'Reilly & Associates也是有利的
.因此现在我想干什么他们都会 为我付账,只要是对Perl有帮助就好.这是一种良好的共生关系.
马: 有没有新的令人感兴趣的计划呢?
拉: 有人建议我写作骆驼书的第三版,除此之外我还没有正式的计划.
马: 哦.介绍一下你自己吧.比如你在哪里上的学,你有什么兴趣爱好 之类的.
拉: 我的童年有一半时间是在洛杉矶南部度过的,然后是在华盛顿. 我从高中毕业之后,进入西雅图太平洋大学,开始学的是化学和音乐
, 然后转到医学,最后的专业是自然和人工语言.之后,我和我妻子参 加了语言学的进修.当时,我们打算去做传教士(准确的说,是圣经
解说员),最后考虑到健康的原因放弃了该计划.有趣的是,传教士们 由Perl上得到的帮助大概会大于我作为一名传教士能够提供的帮助
. 至于说到我的兴趣,这个有点困难,因为我对所有有趣的东西都感 兴趣.说起来就会有很多了,不过有两样例外,即歌剧和肥皂剧-- 太
空题材的影片除外.
马: 你娱乐的时候会做什么?
拉: 读书和听我的妻子给我读书(特别是太空类的).和家里任何人讨论 任何问题.玩填字游戏.玩麻将.练合气道.看动画.逗鱼.
马: 看起来你很忙碌有很有趣味--很好的组合.那么你早饭吃什么?
拉: 我早饭吃很多东西--不过,我通常是在午餐时间吃早饭.
马: 时间过得好快.谢谢你抽空接受采访.非常感谢!