Introduction
簡介
What is Extreme Programming? Does it involve bungee cords?
什么是極限編程(Extreme Programming)?它需要蹦級(jí)保險(xiǎn)繩么?:-)
Extreme Programming (or XP) is a set of values, principles and practices for rapidly developing high-quality software that provides the highest value for the customer in the fastest way possible. XP is extreme in the sense that it takes 12 well-known software development “best practices” to their logical extremes—turning them all up to “10” (or “11” for Spinal Tap fans). See Kent Beck’s introduction to Extreme Programming Explained for more details.
極限編程(Extreme Programming,或簡稱XP)是一套能快速開發(fā)高質(zhì)量軟件所需的價(jià)值觀、原則和活動(dòng)的集合,使軟件能以盡可能快的速度開發(fā)出來并向客戶提供最高的效益。說XP是極限在于它將12個(gè)眾所周知的軟件開發(fā)的“最佳活動(dòng)”都發(fā)揮到極限“10分”(或到“11分”對(duì)超級(jí)發(fā)燒友)。更詳細(xì)的細(xì)節(jié)可參看Kent Beck的關(guān)于極限編程的介紹。
What does this have to do with Windows XP?
它和Windows XP有什么關(guān)系?
Absolutely nothing. In February 2001, Microsoft announced that the next release of their consumer Windows operating system would be called “Windows XP”. The use of “XP” as shorthand for Extreme Programming predates Microsoft’s use of “XP” by 2-3 years.
絕對(duì)無關(guān)。在2001年2月,微軟宣布他們下一個(gè)要發(fā)布的Windows操作系統(tǒng)叫做“Windows XP”,用”XP”做為極限編程的縮寫在2~3年前就預(yù)測(cè)了微軟的”XP”用法。
Is XP a methodology?
XP是一種方法學(xué)么?
No and yes. No, it’s not a methodology in the sense of a lot of paperwork and additional hoops for developers to jump through. But yes, in the sense that it is a repeatable process for developing software, it is in fact a methodology, although a lightweight one.
可以說不是,也可以說是。說它不是一種方法學(xué)是因?yàn)殚_發(fā)者可以跳過許多紙面上的東西和附加的條條框框;說它是,是因?yàn)樗鼘?duì)于開發(fā)軟件來說是一種可重復(fù)的過程,它實(shí)際上也是一種方法學(xué),但是屬于“輕量級(jí)”的。
Alistair Cockburn, who studies methodologies for a living, characterizes XP as a lightweight, low-ceremony, high-discipline methodology.
Alistair Cockburn,一個(gè)研究方法學(xué)的學(xué)者,描述XP為輕量級(jí)的、不講究繁文縟節(jié)的、高紀(jì)律性的方法學(xué)。
Where did XP come from?
XP起源于何處?
XP was originated by Kent Beck, based on his years of practice as an O-O software developer, and in particular, his work with Ward Cunningham using the Smalltalk programming language. Because Smalltalk was the first popular O-O language, Ward and Kent have been doing object- oriented programming longer than just about anyone else.
XP最早是由Kent Beck提出來的,源于他多年的O-O實(shí)踐,特別是他和Ward Cunningham一起使用Smalltalk語言進(jìn)行開發(fā)的工作經(jīng)驗(yàn)。因?yàn)?/SPAN>Smalltalk是第一種流行的O-O語言,Ward和Kent比其他任何人都有更長的面向?qū)ο蟮木幊探?jīng)歷。
What are the basic practices of XP?
XP的基本實(shí)踐是什么?
The 12 core practices of XP are:
12個(gè)XP的核心實(shí)踐是:
The Planning Game: Business and development cooperate to produce the maximum business value as rapidly as possible. The planning game happens at various scales, but the basic rules are always the same:
游戲策劃:結(jié)合業(yè)務(wù)和開發(fā)以盡可能快地產(chǎn)生商業(yè)效益。游戲策劃的范圍各有不同,但基本原則都是一樣的:
Business comes up with a list of desired features for the system. Each feature is written out as a User Story, which gives the feature a name, and describes in broad strokes what is required. User stories are typically written on 4x6 cards.
業(yè)務(wù)提供了一張系統(tǒng)的期望特征表,把每個(gè)特征作為一個(gè)用戶需求(User Story)記錄下來,其中包括特征名和需求的各種提法。用戶需求典型地是寫在4x6的卡片上。
Development estimates how much effort each story will take, and how much effort the team can produce in a given time interval (the iteration).
開發(fā)工作要估計(jì)每條需求所需要的工作量,以及開發(fā)團(tuán)隊(duì)在一個(gè)時(shí)間段(一次迭代)里能完成的工作量。
Business then decides which stories to implement in what order, as well as when and how often to produce a production releases of the system.
然后企業(yè)就確定用何種順序?qū)崿F(xiàn)哪些用戶需求,同時(shí)確定可發(fā)布的產(chǎn)品以的發(fā)布頻度。
Small Releases: Start with the smallest useful feature set. Release early and often, adding a few features each time.
短時(shí)發(fā)布:以實(shí)現(xiàn)最小的可用特征集開始。盡早發(fā)布和更新,每次只增加少數(shù)幾個(gè)新特征。
System Metaphor: Each project has an organizing metaphor, which provides an easy to remember naming convention.
系統(tǒng)綽號(hào):每個(gè)項(xiàng)目有一個(gè)有規(guī)律的綽號(hào),提供容易記住的命名規(guī)則。
Simple Design: Always use the simplest possible design that gets the job done. The requirements will change tomorrow, so only do what’s needed to meet today’s requirements.
簡要設(shè)計(jì):使用盡可能最簡單的設(shè)計(jì)來完成工作。需求也許明天就會(huì)改變,因此我們所需的只是完成今天所遇到的需求。
Continuous Testing: Before programmers add a feature, they write a test for it. When the suite runs, the job is done. Tests in XP come in two basic flavors.
連續(xù)測(cè)試:在程序員增加一項(xiàng)特征前就完成測(cè)試程序。當(dāng)整個(gè)系統(tǒng)能運(yùn)行時(shí),測(cè)試任務(wù)也就結(jié)束了。XP中的測(cè)試包括兩種類型:
Unit Tests are written by the developers to test functionality as they write it. Each unit test typically tests only a single class, or a small cluster of classes.
單元測(cè)試(Unit Tests)(代碼)是開發(fā)者編寫用來對(duì)他們所做的程序進(jìn)行功能測(cè)試的。每個(gè)單元測(cè)試典型地只測(cè)試單個(gè)的類或很少幾個(gè)類的組合。
Acceptance Tests (also known as Functional Tests) are specified by the customer to test that the overall system is functioning as specified. Acceptance tests typically test the entire system, or some large chunk of it. When all the acceptance tests pass for a given user story, that story is considered complete.
驗(yàn)收測(cè)試(也被稱為功能測(cè)試)是由客戶指定來測(cè)試整個(gè)系統(tǒng)是否完成既定功能。驗(yàn)收測(cè)試通常測(cè)試整個(gè)系統(tǒng),或系統(tǒng)中一些大的模塊。當(dāng)驗(yàn)收測(cè)試達(dá)到某條給定需求后,此需求就認(rèn)為已經(jīng)完成了。
Refactoring: Refactor out any duplicate code generated in a coding session. You can do this with confidence that you didn’t break anything because you have the tests.
求精(Refactoring):去掉在編碼過程中產(chǎn)生的任何重復(fù)代碼,你可以自信地認(rèn)為這么做不會(huì)破壞任何東西,因?yàn)槟氵有測(cè)試作為后盾。
Pair Programming: All production code is written by two programmers sitting at one machine. Essentially, all code is reviewed as it is written.
編程對(duì)子:所有代碼都是坐在同一臺(tái)機(jī)器前的兩個(gè)程序員共同編寫的,因此所有代碼在編寫的同時(shí)就完成了復(fù)查工作。
Collective Code Ownership: No single person “owns” a module. Any developer is expect to be able to work on any part of the codebase at any time.
集體代碼所有權(quán):沒有單獨(dú)的一個(gè)人能“擁有”一個(gè)模塊,所有開發(fā)者都能在任何時(shí)候針對(duì)代碼庫的任何部分進(jìn)行工作。
Continuous Integration: All changes are integrated into the codebase at least daily. The tests have to run 100% both before and after integration.
連續(xù)整合:至少每天都將所有的改變整合到代碼庫中,在整合前后都要進(jìn)行100%的測(cè)試。
40-Hour Work Week: Programmers go home on time. In crunch mode, up to one week of overtime is allowed. But multiple consecutive weeks of overtime are treated as a sign that something is very wrong with the process.
每周4干40小時(shí):讓開發(fā)人員按時(shí)回家。在特殊情況下,最多也只允許加班一周,但連續(xù)加班幾周就是工作過程出了問題的跡象。
On-site Customer: Development team has continuous access to a real live customer, that is, someone who will actually be using the system. For commercial software with lots of customers, a customer proxy (usually the product manager) is used instead.
在位(on-site)客戶:開發(fā)團(tuán)隊(duì)要經(jīng)常和活生生的客戶接觸,即系統(tǒng)的實(shí)際用戶。對(duì)于有很多客戶的商業(yè)軟件,可以用客戶代理(經(jīng)常就是產(chǎn)品經(jīng)理)來代替。
Coding Standards: Everyone codes to the same standards. Ideally, you shouldn’t be able to tell by looking at it who on the team has touched a specific piece of code.
編碼標(biāo)準(zhǔn):每個(gè)人都按相同的標(biāo)準(zhǔn)編寫代碼。理想情況下,你無法通過看代碼的形式來說出是團(tuán)隊(duì)中的誰編寫的。
What does a typical extreme programming project look like?
一個(gè)典型的極限開發(fā)項(xiàng)目是什么樣的?
The first thing you’d notice is that all the programmers are in a room together, usually sitting around a large table in the middle of the room. The programmers may have desks or offices nearby, but you can tell by the piles of books are piled that the big table is where the action is.
你注意到的第一件事是所有程序員都同在一間屋里,經(jīng)常是圍坐在房屋中間的一張大桌子邊。程序員們也許在旁邊也有桌子和辦公室,但你可通過所堆起來的成堆的書來確定大桌子才是真正的活動(dòng)場(chǎng)所。
XP teams work in a series of fixed iteration cycles. Iterations typically last 1, 2 or 3 weeks each depending on the team. (A given team will almost always use same the iteration size for every iteration.)
XP團(tuán)隊(duì)按一系列固定的迭代周期進(jìn)行工作,根據(jù)團(tuán)隊(duì)的不同一個(gè)迭代周期通常持續(xù)1~3星期。(給定團(tuán)隊(duì)通常在每個(gè)開發(fā)周期都用相同的時(shí)間)
At the beginning of each iteration, the team gets together with the customer for a planning meeting. In that meeting, they go over the features the customer wants done in that iteration, breaking each feature down into individual engineering tasks. Individual developers then sign up for specific
tasks, and estimate those tasks. No developer is allowed to sign up for more work in the coming iteration than he completed in the previous iteration.
在每個(gè)開發(fā)周期的開始,團(tuán)隊(duì)和客戶一起開一個(gè)計(jì)劃會(huì)議。在會(huì)上他們要核實(shí)客戶希望在本周期內(nèi)要完成的特性,將每個(gè)特性分割為單獨(dú)的工程任務(wù)。然后每個(gè)開發(fā)人員登記承擔(dān)特定的任務(wù)并估計(jì)這些任務(wù)的工作量。不允許開發(fā)人員在下一個(gè)周期中承擔(dān)比他上一個(gè)周期中所能完成的更多的工作。
During the rest of the iteration, the team will implement the features they signed up for, pair prog- ramming on all production code. All code is written test-first—that is, the developers don’t write any code until they have a failing test case. The developers write unit tests to test individual classes and subsystems. The customer provides functional or acceptance tests to validate the features that the programmers are developing.
在迭代周期的其他時(shí)間內(nèi),團(tuán)隊(duì)要實(shí)現(xiàn)他們所登記承擔(dān)的任務(wù),所有代碼由編程對(duì)子一起完成。所有代碼都是以測(cè)試第一(test-first)的原則來寫的,也就是說開發(fā)者在程序沒有出現(xiàn)測(cè)試失敗之前不必修改代碼。如果沒有完成測(cè)試程序,開發(fā)人員就不能寫功能代碼?蛻籼峁┕δ軠y(cè)試或驗(yàn)收測(cè)試來核實(shí)開發(fā)者所開發(fā)出來的特性。
At the end of the iteration (usually on a Friday), the programmers deliver a working system to the customer. The system may not be complete, but all functionality that is implemented works com- pletely, without bugs. The customer accepts delivery, and the team goes home early. The next Monday everyone meets again to plan the next iteration, and the cycle repeats itself.
在迭代周期結(jié)束時(shí)(通常是星期五),開發(fā)團(tuán)隊(duì)為客戶提供一個(gè)可工作的系統(tǒng)。此系統(tǒng)可能不完整,但實(shí)現(xiàn)的所有功能都能完全無bug地工作,客戶接受此版本后開發(fā)團(tuán)隊(duì)就可早回家休息。到了下星期一所有人重新聚集在一起策劃下一個(gè)迭代周期的工作,如此重復(fù)循環(huán)。
Actual product release is almost a non-event. The customer takes delivered system from some iteration, and distributes it to the end users. The system is always very nearly defect-free, so the only question is when the developers have added enough functionality to make it worthwhile for the end users to upgrade.
一次性發(fā)布產(chǎn)品幾乎是不可能的?蛻裟玫浇(jīng)過一些迭代周期開發(fā)出的系統(tǒng)就發(fā)布給最終用戶,這個(gè)系統(tǒng)通常幾乎是沒有缺陷的,因此唯一的問題是什么時(shí)候開發(fā)者才能增加足夠的功能以值得最終用戶去進(jìn)行升級(jí)。
How big a project will XP work with?
XP可以完成多大的項(xiàng)目?
Easily up to a dozen programmers. Up to twice that with some difficulty. Beyond that, you’ll need something else, either augmenting XP with more traditional heavyweight practices, or splitting the project among two or more regular XP teams, with some teams becoming customers for other teams.
很容易完成一個(gè)需要有12人的項(xiàng)目. 若要完成一個(gè)兩倍大的項(xiàng)目就比較困難了。超過這些, 你就會(huì)需要一些別的東西, 或添加一些傳統(tǒng)處理大任務(wù)型項(xiàng)目的實(shí)踐, 或把這個(gè)項(xiàng)目組分解到兩個(gè)或兩個(gè)以上XP團(tuán)隊(duì)中, 讓其中一些團(tuán)隊(duì)當(dāng)另外一些團(tuán)隊(duì)的客戶。
How does XP compare to UML?
XP與UML是什么關(guān)系?
XP is a development process; UML is a design notation. Most XPers are fluent in UML, and periodically draw UML diagrams on marker boards to work out design issues. Most XP projects don’t have reams of printed UML diagrams, although there may be a brief design overview document. nbspthat contains a few simple diagrams to show canonical class relationships in the system.
XP是一個(gè)開發(fā)的過程; UML是一種設(shè)計(jì)符號(hào)。 大部分XP開發(fā)人員對(duì)UML很熟悉, 并且隨時(shí)地在記事板上畫一些UML圖表以便能夠想出更好的設(shè)計(jì)方案。盡管會(huì)有一些包含系統(tǒng)中主要類關(guān)系的簡明概要設(shè)計(jì)文檔,大多數(shù)XP項(xiàng)目并沒有大量打印出來的UML圖表。
How does XP compare to RUP?
XP與RUP是什么關(guān)系?
The Rational Unified Process, or RUP, is&n