教堂与集市

本书平装本的封面 《大教堂与市集》(The Cathedral an...

本书平装本的封面

大教堂与市集》(The Cathedral and the Bazaar)是埃里克·斯蒂芬·雷蒙(Eric Steven Raymond)所撰写的软件工程方法论。以Linux的核心开发过程以及作者自己主持开发的开放源代码软件──Fetchmail为讨论案例。文章在1997年5月27日发表,并在1999年出版成书。

简介

本书讨论两种不同的自由软件开发模式:

  • 大教堂模式(The Cathedral model):源代码在软件发行后公开,但在软件的每个版本开发过程中是由一个专属的团队所控管的。作者以GNU Emacs及GCC这两软件为例。
  • 市集模式(The Bazaar model):源代码在开发过程中即在互联网上公开,供人查看及开发。作者以Linux核心的创始者林纳斯·托瓦兹带领Linux核心的开发为例,亦引用fetchmail的开发为例。

此书的要义是“让够多人看到源代码,错误将无所遁形”(Given enough eyeballs, all bugs are shallow)林纳斯定律。作者表示大教堂模式的软件开发让程序调试的时间大幅增加,因为只有少数的开发者可参与修改工作。市集模式则相反。

从开发自由软件所学到的教训

雷蒙指出了19点在他开发多个软件项目中所学到的 "教训"。每个学到的教训都跟开放软件所使用的最佳实践有关:

  1. 好软件都是起源于程序发展者要解决切身之痛。
  2. 优秀的程序师知道要写程序,伟大的程序师知道要改写(和重复利用)程序。
  3. 计划好如何舍弃一条路吧,你迟早会想尽办法这么做的(引自 Frederick Brooks'《人月神话:软件项目管理之道》)。
  4. 抱持正确的态度,就会发现有趣的问题。
  5. 当你对一个问题不再感兴趣时,你最后的责任就是找位能胜任的接棒人。
  6. 把用户视为共同开发者来对待,可以让你伤最少的脑筋,但做到源代码的快速改善和有效率地调试。
  7. 尽早且经常发表新版本,并且倾听用户的意见。
  8. 在一群足够多的 beta 测试者与共同开发者的情况下,几乎程序中的每一个问题都可以很快地找出来,并且由某个人很直觉的解决。
  9. 聪明的数据结构配上笨拙的代码要比相反的组合好。
  10. 如果你视 beta 版测试者如同你最珍贵的资源,那么他们会以此做为回报。
  11. 体认用户提供的巧思,以获取好点子,有时候越后到的越好。
  12. 通常,最适切和最有创意的解题法来自于发觉自己对问题原先的观念是错误的。
  13. 设计上完美,不是“没有东西能再被加入”,而是“没有东西能再被移出”。
  14. 任何的工具以我们所知道的方法来使用都会有用,但一个真正了不起的工具会以你从未想过的使用方法来发挥它的功能。
  15. 写作任何的通信闸软件时,要尽可能地不去扰动到通信的资料流 -- 并且绝对不要丢掉其中任何的信息,除非接收方强迫你这么做。
  16. 当你设计的语言不是严谨到“Turing-complete”,你可以采用比较平易的语法。
  17. 一个保密系统是否安全依存于它隐藏的秘密,注意不要有“虚拟秘密”。
  18. 解决一个有趣的问题,由找到一个你觉得有趣的问题开始。
  19. 假如项目发展协调者拥有至少跟互联网一样好的媒体,而他也不靠强制力来领导,那么一群人必定胜过一个人。

影响

此文让大部分的开放源代码及自由软件的开发项目采用市集模式,甚至原来采用大教堂模式的GNU Emacs及GCC也是如此。Netscape网页浏览器后来发布源代码,并启动Mozilla项目,也或多或少受到这篇文章的启发。

大教堂与市集也被延伸到非电脑软件的开发上面。例如维基百科就是市集模式,而Nupedia与大英百科全书就是大教堂模式。

出版

欧莱礼出版社于1999年发行此书的创举是,首次商业印刷出版的书以Creative Commons授权模式出版。

本书(原文)的国际标准书号是 ISBN 978-1-56592-724-7(精装本)、ISBN 978-0-596-00108-7(平装本)。

本文来自作者[冷亦]投稿,不代表羽隶号立场,如若转载,请注明出处:https://m.law-prophet.com/wiki/202508-2950.html

(7)

文章推荐

  • 猪猪侠与星航概述:太阳之子排名解析

    猪猪侠和星航介绍星航,是《猪猪侠之竞速小英雄5》和《猪猪侠之竞速小英雄6》中的重要角色。是一位冷静谨慎的赛车手,也是竞速星球车神银河的儿子。对机械有敏锐的感知力,是赛车场上的天才,具有百折不挠、充满着乐观主义的精神,与队友猪猪侠组成超星车队,在

    2025年08月12日
    26
  • 我来告诉你“锦绣乐游麻将有挂吗”原来真实可以装挂

    家们!今天小编来为大家解答锦绣乐游麻将有挂吗这个问题咨询软件客服徽信 的挂在哪里买很多人还不知道,现在让我们一起来看看吧!一、记牌器怎么全显示你需要获得记牌器才能全部显示,否则只显示前面几张牌的数据。如下图所示:获取开挂的软件方法如下:可以通过

    2025年08月24日
    11
  • 历史性成就:创投在西澳大利亚稀土领域取得最佳成绩

      VentureMinerals在西澳大利亚中西部的Jupiter矿区,以3430ppm的稀土氧化物总量(TREO)开采出5700万颗稀土矿,创下公司历史新高,这为该矿区40平方公里的资源在年底前交付奠定了基础。就在前一天,该公司确认在以300万美元出售位于

    2025年08月24日
    14
  • 专业讨论“麻将有挂”原来真可以开挂

    麻将有挂这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,而且好像能看到其他人的牌一样。所以很多小伙伴就怀疑这款游戏是不是有挂,实际上这款游戏确实是有挂的通过添加客服微:本司针对手游进行匹配,选择我们的四大理由:1

    2025年08月25日
    16
  • 科普一下“蜀州麻将大福开挂教程”其实真的确实有挂

    蜀州麻将大福开挂教程这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,而且好像能看到其他人的牌一样。所以很多小伙伴就怀疑这款游戏是不是有挂,实际上这款游戏确实是有挂的通过添加客服微:本司针对手游进行匹配,选择我们的

    2025年08月25日
    15
  • 分享热点“微乐陕西三代辅助软件好用不”的确有挂

    微乐陕西三代辅助软件好用不是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加入我们(QQ群聊)免费测试,先看效果下载使用。手机打牌可以一键让你轻松成为“必赢”。其操作方式十分简单,打开这个应用便可以自定义手机打牌系统规律,只需要输

    2025年08月26日
    10
  • 查到实测辅助“德州手游透视”分享装挂详细步骤

    网上科普有关德州手游透视”话题很是火热,小编也是针对微乐麻将的技术支持和安全性寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。您好,德州手游透视这款游戏可以开挂的,确实是有挂的,通过微信【游戏】很多玩家在这款游戏

    2025年08月29日
    11
  • 教程解析“贵州地道麻将有挂吗”分享装挂步骤

    您好:贵州地道麻将有挂吗这款游戏是可以开挂的,软件加微信【添加图中微信】确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,而且好像能看到其他人的牌一样。所以很多小伙伴就怀疑这款游戏是不是有挂,实际上这款游戏确实是有挂的,添加客服微信【

    2025年08月30日
    14
  • 最新昭通疫情动态:新增病例人数及防控措施详解

    0自驾车到吉客隆超市,15:30到南大街粮食局门口临时核酸采样点采核酸后返回家中未外出。11月24日11:20闭环转运至凤凰山医院隔离观察。初筛阳性20:11月17日-18日07:00乘坐私家车从小南区家中到昭阳区第四小学古城校区,17:40在状元坊教育,23:00打滴滴车返家后未外出。11月19

    2025年08月31日
    12
  • 广州南沙报告新增确诊病例,启动封控措施

      4月4日0-24时,全省新增本土确诊病例3例,广州报告2例,茂名报告1例;新增本土无症状感染者1例,东莞报告。  全省新增境外输入确诊病例6例(其中1例为无症状感染者转确诊),广州报告4例,2来自加拿大,其余2例分别来自韩国和孟加拉国;深圳报告

    2025年09月02日
    4

发表回复

本站作者后才能评论

评论列表(4条)

  • 冷亦
    冷亦 2025年08月30日

    我是羽隶号的签约作者“冷亦”!

  • 冷亦
    冷亦 2025年08月30日

    希望本篇文章《教堂与集市》能对你有所帮助!

  • 冷亦
    冷亦 2025年08月30日

    本站[羽隶号]内容主要涵盖:国足,欧洲杯,世界杯,篮球,欧冠,亚冠,英超,足球,综合体育

  • 冷亦
    冷亦 2025年08月30日

    本文概览:本书平装本的封面 《大教堂与市集》(The Cathedral an...

    联系我们

    邮件:羽隶号@sina.com

    工作时间:周一至周五,9:30-18:30,节假日休息

    关注我们