开源程序架构 卷一 [序言]

最近准备翻译一个不错的架构研究系列:The Architecture of Open Source Applications 。对架构感兴趣的童子可以关注一下,或者对英语学习感兴趣也可以。全书两大卷,包含了40多个经典开源项目的架构解析,参与人员大多都是一线主力开发者。
  闲言少叙,献上序言如下:
  Carpentry is an exacting craft, and people can spend their entire lives learning how to do it well. But carpentry is not architecture: if we step back from pitch boards and miter joints, buildings as a whole must be designed, and doing that is as much an art as it is a craft or science.

木工是一门要求严格的工艺,人们可以花一辈子的时间学习如何把它做好。但木工不是建筑学:如果我们从木板搭帐篷和接缝衔接中抽身来看,建筑必须作为一个整体被设计。这样做是一门工艺或科学也是一门艺术。

Programming is also an exacting craft, and people can spend their entire lives learning how to do it well. But programming is not software architecture. Many programmers spend years thinking about (or wrestling with) larger design issues: Should this application be extensible? If so, should that be done by providing a scripting interface, through some sort of plugin mechanism, or in some other way entirely? What should be done by the client, what should be left to the server, and is "client-server" even a useful way to think about this application? These are not programming questions, any more than where to put the stairs is a question of carpentry.

编程也是一门要求严格的工艺,人们可以穷其毕生精力学习如何把它做好。但编程并不是软件架构。许多程序猿花费数年思考(或斟酌)更重要的设计问题:这个应用程序可以被扩展吗?如果可以,应该做一个脚本界面,通过某种插件机制或者其它方法来完成?客户端应该做什么,应该在服务器端做什么,对于这个应用程序“客户端-服务器”是一个好的实现方式吗?这些都不是编程问题。

Building architecture and software architecture have a lot in common, but there is one crucial difference. While architects study thousands of buildings in their training and during their careers, most software developers only ever get to know a handful of large programs well. And more often than not, those are programs they wrote themselves. They never get to see the great programs of history, or read critiques of those programs' designs written by experienced practitioners. As a result, they repeat one another's mistakes rather than building on one another's successes.

建筑架构和软件架构有很多共通之处,但有一个关键的区别。在培训和职业生涯期间,建筑师会研究成千上万的建筑物,而大多数软件开发者只了解少数自己亲身经历的大型程序。他们从来没有了解过大程序的历史,或阅读评论那些经验丰富的从业者的设计和实现。结果,他们重复对方的错误而不是建立在彼此的成功。

This book is our attempt to change that. Each chapter describes the architecture of an open source application: how it is structured, how its parts interact, why it's built that way, and what lessons have been learned that can be applied to other big design problems. The descriptions are written by the people who know the software best, people with years or decades of experience designing and re-designing complex applications. The applications themselves range in scale from simple drawing programs and web-based spreadsheets to compiler toolkits and multi-million line visualization packages. Some are only a few years old, while others are approaching their thirtieth anniversary. What they have in common is that their creators have thought long and hard about their design, and are willing to share those thoughts with you. We hope you enjoy what they have written.

这本书是我们改变这种局面的尝试。每一章描述了一个开源程序的架构:它是如何构建的,各部分如何交互,为什么这样构成,还有吸取的教训(这些教训也适用于其它项目的重要的设计问题)。这些描述由懂得最好软件的人所写,他们拥有几年或几十年的设计和重构复杂应用程序的经验。从简单的绘图程序程序和基于web的电子表格到编译器工具集和数百万行的可视化软件包。有些只有几年历史,有的则接近三十年。他们的共同点是,他们的创作者都经过漫长而艰难的设计,并且都愿意和你分享这些想法。我们希望你喜欢他们所写的。

生词:
carpentry ['ka:pəntri] : n.木器;木工工艺;木工业
craft [kra:ft] : n.工艺;手艺;太空船
architecture ['ɑːkɪtektʃə] : n.建筑学;建筑风格;架构
pitch [pɪtʃ] : n.沥青;树脂;球场
miter ['maɪtə] : n.斜接

wrestling ['resliŋ] :n. v.摔跤;扭斗 wrestling with :为......绞尽脑汁;受困于.......
plugin [plʌgɪn] : n.插件
mechanism ['mɛkənɪzəm] : n.机制;原理;

crucial ['kuru:ʃəl] : adj.重要的
more often than not : 往往
critiques [kri'ti:ks] vt.评论;批判

lessons : n.经验教训;课程
spreadsheets : n.电子表格
approaching : v.接近
anniversary [,æni'və:səri] : 周年纪念日

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容

  • **2014真题Directions:Read the following text. Choose the be...
    又是夜半惊坐起阅读 9,244评论 0 23
  • 7月过去了,昨天学习真谛领悟小组集会,总结了一下各自的7月,革命没有尽头,完美没有终点,加油。 七月的最后一个周末...
    斯年华阅读 88评论 0 0
  • 何为即时培训,度娘也没有给出明确的定义。我妄自给它定义为:在发现问题后第一时间进行纠正指导,或组织培训。即时培训主...
    礼尚往来可好阅读 605评论 0 1
  • #微写作#第1篇 “你最近气色不错呢。”今天早餐的时候,同事这样对我说。些许的欢喜之余,我再一次觉得运动的确是件值...
    ChanGi阅读 282评论 0 3
  • 0 由于工作需要,最近开始接触MongoDB,对于一个已经习惯了传统SQL的程序员来说,进入NoSQL可以说是需要...
    一只老辣鸡阅读 1,727评论 6 13