Thousand Squared

希望能分享一些學習心得啊啊啊~~~.

Pair Programming心得

| Comments

在上個禮拜之前,寫程式對我來說,大部分都是一個人單打獨鬥的事情。

學校作業、碩士論文,一人一份,時間到了記得交出來。
工作時期,接案Case,一人一份,老闆覺得兩個人接同一個案子太浪費成本了!

以上的種種,讓寫程式都大部分為一個人做的事情,頂多就是問問資深人員一些架構問題等等…

最近到了新環境,採用了Pair Programming,真是令我既期待又怕受傷害阿阿阿阿~

什麼是Pair Programming?

Pair Programming來自Extreme Programming,它是Extreme Programming裡的其中一項作業。 (Extreme Programming是一種軟體開發模式,我也才剛接觸所以不太熟)

簡單來說,就是兩個人坐在一起,配備
- 兩個螢幕
- 兩個鍵盤
- 兩個滑鼠
- 一台主機

沒錯!一台主機,就是兩個人coding同一份程式碼!

雖然以前有聽說過這種開發方式,但也只是聽說…

第一次參與Pair時,就是一直看一直看,一直看Senior以飛快的速度寫程式….
然後換我寫時,慢的跟新手一樣,還常常打錯字,鍵盤都握不好啦…0rz

沒想到在coding時,旁邊有人監督竟然這麼有壓力,怕變數名稱取的不好,怕打字速度太慢,怕誤會剛剛的演算法。讓我一開始pair時coding速度變很慢…。

Pair的好處

1. 品質

程式的品質真的好很多。

從最基本的變數名稱,邏輯判斷,演算法等等。一人寫程式,一人監督的概念,讓程式不會亂寫。

該抽出來的function就抽,該定義constant就定義,該寫的註解不會漏掉,不會有多餘的if else,可讀性提高許多,而且Bug真的變少了! (很明顯感受到程式Compile執行後就正確無誤,真是太神奇啦!)

2. 專心

Pair互相監督討論,根本無法打混(除非兩個人一起打混…XD)。
這陣子下來發現,Pair時會超級認真的,討論很起勁還會忘記吃飯!
(因此Pair完也會有用腦過度的感覺…)

3. 維護

Pair雙方都對程式架構有相當程度的了解,因此不用擔心交接問題。
這對小公司來說應該算是最實用的地方了,不會產生爛攤子而沒人收拾。

對我而言,從pair上可以更快了解此專案內容。透過不斷的思考、討論、問與答,比起一個人慢慢的看code,效率要好上十幾倍呀! 而經由senior的在旁指導,讓我學習到更多軟體開發的技巧,也少走很多的冤枉路,真是太值得了。

Pair的困擾

Pair時也有幾個會困擾開發者的事情:

1. IDE的選擇

有人習慣用XCode,有人習慣用Eclips、Notepad++等,這些IDE的熱鍵有時都不同,當兩個人湊在一起時,就必須向某一方妥協,總不可能一直切換IDE寫吧。 為了有共識,我們公司統一Pair開發用IDE,也統一了熱鍵,方便開發。

2. 查資料時效率不好

寫到一半卡住,要google時,會發現兩人用一台電腦真是不好查資料…因為每個人的閱讀習慣不同, 因此常常會一個人在查,另一個人就在發呆…。為了克服這個問題,我們還是會另外放一台筆電在旁邊,做為查資料時使用。

3. 作息要一致

若Pair的作息不同,Pair的時間就會變少了,我想這也是Pair的宿命吧。

4. 學習時間變少

我們公司是full time pair,這有一個意想不到的缺點,就是沒有自己的時間呀。
上班就是pair到下班,想要學新技術,就必須自己找時間學習。 不知不覺壓力就變大了哈哈哈
(不過這或許是好事吧XD)

總結

我覺得pair programming真的還蠻適合用在規模不大專案的開發上。 不僅程式品質變好,開發速度其實也是變快的(Debug時間大大變少…XD)。

可惜pair programming在台灣老闆耳中聽起來就很像是一種增加成本的開發方式…0rz。

如果有時間的話,就來試試Pair Programming吧。

參考資料:

  1. Pair Programming - Wiki Pair Programming.
  2. Extreme Programming - Wiki Extreme Programming.

Comments