總結編程過程中的一些誤區(qū)
在過去的幾年里,有過許多結對編程的經(jīng)歷。有時在團隊里進行,有時在客戶那里,有時在coding dojo(一種編程模式,幾個程序員一起合作完成一個任務),有時在我的開源項目里。對于那些知道如何結對編程的程序員來說,這種模式很棒,很高效。
但是你不能指望在兩個程序員面前擺臺電腦,就指望他們一開始就做得很棒。結對編程需要學習,程序員需要知道實施者(敲鍵盤的人)和領航員之間的區(qū)別。下面來看看些細節(jié)。
在結對編程中,我遇到了一些誤區(qū),列在下面。
一、領航員誤區(qū)
1. 發(fā)號施令者
喜歡發(fā)號施令的人總是對敲鍵盤的人說:“到末行,加個反括號,然后…”。他不去關注解決方法和下一步該怎么做,而過度關注一些編程細節(jié)。
事實上,他希望他自己來掌控鍵盤。所以當你碰到一個喜歡發(fā)號施令的人,那么將鍵盤交給他吧,轉(zhuǎn)換領航員的角色。
2. 拼寫糾錯者
拼寫糾錯者坐在你旁邊,糾正你輸入的每個錯誤字符。當然,他沒有時間來真正的進行導航。
和糾錯者商量一下,當他給你糾錯的時候讓他請你喝一杯咖啡(或者任何你想要的東西)。
3. 吹毛求疵者
吹毛求疵者會指責你寫的每行代碼。當他的意見正確時,他會一意孤行,不用你已經(jīng)寫好的代碼,而完全照著他的想法。
就如自由爵士音樂人都是復用其他樂隊成員的音符,來構造成一首曲子一樣,好的結對編程也應基于現(xiàn)有的基礎上進行推進。
試著轉(zhuǎn)換角色,也許吹毛求疵者就會變成一個目中無人的人。
4. 默不作聲者
默不作聲者是那些幾乎不發(fā)表意見的人。他僅僅坐在那里看著你工作。
試著問下他對你的方法有什么意見,或者問他下一步該寫什么測試代碼。
評論