惡魔:「軟件技術的變化如此之快,勢不可擋,這是它的本性。繼續用你熟悉的語言作你的老本行吧,你不可能跟上技術變化的腳步。」編程
你不須要一口氣爬上10樓,而須要一直在攀登,因此最後看起來就像只要再上一二層。若是你對全部這些技術都一無所知,想要立刻登上這10樓,確定會讓你喘不過氣來。並且,這也會花很長時間,期間還會有更新的技術出現。框架
現今有不少方法和工具能夠幫助咱們繼續充電:工具
天使:「跟蹤技術變化。你不須要精通全部技術,但須要清楚知道行業的動向,從而規劃你的項目和職業生涯。」單元測試
惡魔:「不要和別人分享你的知識——本身留着。你說由於這些知識而成爲團隊中的佼佼者,只要本身聰明就能夠了,不用管其餘失敗者。」學習
團隊中的開發者們各有不一樣的能力、經驗和技術。每一個人都各有所長。不一樣才能和北京的人混在一塊兒,是一個很是理想的學習環境。開發工具
在一個團隊中,若是知識你我的技術很好還遠遠不夠。若是其餘團隊成員的知識不夠,團隊也沒法發揮其應有的做用:一個學習型的團隊纔是較好的團隊。測試
當開發項目的時候,你須要使用一些術語或者隱喻來清晰地傳達 設計的概念和意圖。若是團隊中的大部分紅員不熟悉這些,就很難進行高效的工做。再好比你參加了一個課程或者研討班以後,所學的知識若是不用,每每就會忘記。因此,你須要和其餘團隊成員分享所學的知識,把這些知識引入團隊中。網站
找出你或團隊中的高手擅長的領域,幫助其餘的團隊成員在這些方面迎頭遇上(這樣作還有一個好處是,能夠討論如何將這些東西應用於本身的項目中)。插件
「午飯會議」是在團隊中分享知識很是好的方式。在一週之中挑選一天,事先計劃午飯時彙集在一塊兒,這樣就不會擔憂和其餘會議衝突,也不須要特別的申請。爲了下降成本,就讓你們自帶午飯。設計
每週,要求團隊中的一我的主持講座。他會給你們介紹一些概念,演示工具,或者作團隊感興趣的任何一件事情。你能夠挑一本書,給你們說書哦其中一些特別內容、項目或者實踐。不管什麼主題均可以。
從每週主持講座的人開始,先讓他講15分鐘,而後,進行開放式討論,這樣每一個人均可以發表本身的意見,討論這個主題對於項目的意義。討論應該包括所能帶來的益處,提供來自本身應用程序的示例,並準備好聽取進一步的信息。
這些午飯會議很是有用。它促進了各鎮團隊對這個行業的瞭解,你本身也能夠從其餘人身上學到不少東西。優秀的管理者會重用那些能提升其餘團隊成員價值的人,所以這些活動也直接有助於你的職業生涯。
天使:「提供你和團隊學習的更好平臺。經過午飯會議能夠增進每一個人的知識和技能,並幫助你們彙集在一塊兒進行溝通交流。喚起人們對技術和技巧的激情,將會對項目大有裨益。」
惡魔:「那就是你一向的工做方法,而且是有緣由的。這個方法也很好的爲你所用。開始你就掌握了這個方法,很明顯它是最好的方法。真的,從那之後就不要再改變了。」
隨着科技進步,曾經很是有用的東西每每會靠邊站。它們再也不有用了,它們還會下降你的效率。對於大多數的商業應用,技術已經有了巨大的變化,再也不像過去那樣,到處考慮內存佔用、手動的重複佔位及手工調整彙編語言。
Expensive mental models aren't discarded lightly
丟棄已經會的東西並不容易,不少團隊在猶豫。在學習一門新技術的時候,多問問本身,是否把太多舊的態度和方法用在了新技術上。打破舊習慣很難,更難的是本身尚未意識到這個問題。
這也不是說你真的要徹底丟棄它們。其實,根據具體狀況還能夠運用舊知識。
應該力求儘量徹底轉入新的開發環境。例如,學習一門新的編程語音時,應使用推薦的集成開發環境,而不是你過去開發時用的工具插件。用這個工具編寫一個和過去徹底不一樣類型的項目。轉換的時候,徹底不要使用過去的語言開發工具。只有更少被舊習慣牽絆,才更容易養成新習慣。
天使:「學習新的東西,丟棄舊的東西。在學習一門新技術的時候,要丟棄會阻止你前進的舊習慣。」
惡魔:「接受別人給你的解釋。別人告訴你問題出在了什麼地方,你就去看什麼地方。不須要再浪費時間去追根究底。」
前面談到的一些習慣是關於如何提升你和團隊的技術的。下面有一個習慣幾乎老是有用,能夠用於設計、調試以及理解需求。
假設,應用系統出了大問題,它們找你來修復它。但你不熟悉這個應用系統,因此他們會幫助你,告訴你問題必定是出在哪一個特殊的模塊中——你能夠放心地忽略應用系統的其餘地方。你必須很快的解決這個問題,由於跟你合做的這些人耐心也頗有限。
當你受到那些壓力的時候,也須要會以爲受到了脅迫,不想去深刻了解問題,並且別人告訴你的已經夠深刻了。然而,爲了解決問題,你須要很好的瞭解系統的全局。你須要查看全部你認爲和問題相關的部分——即便其餘人以爲這並不相干。爲了解決問題,你須要知道許多可能的影響因素。當找人詢問任何相關的問題時,讓他們耐心的回答你的問題,這是你的職責。
或者,假設你和資深的開發者一塊兒工做。它們可能比你更瞭解這個系統。但他們也是人,有時他們也會忘記一些東西。你的問題甚至會幫助他們理清思路。你從一個新人角度提出的問題,給他們提供了一個新的視角,也許就幫助他們解決了一隻使人困擾的問題。
「爲何」時一個很是好的問題。事實上,在一本流行的管理圖書《第五項修煉》中,做者建議,在理解一個問題的時候,須要漸次地問5個以上的「爲何」。它是很好的方式,進一步挖掘簡單直白的答案,經過這個路線,設想就會更加接近事實真相。
真的嗎?爲何呀?
爲何呀?
天使:「不停地問爲何。不能只知足於別人告訴你的表面現象。要不停地提問直到你明白問題的根源。」
惡魔:「咱們很長時間沒有進行代碼複審,因此這週會複審全部的代碼。此外,咱們也要作一個發佈計劃了,那就從星期二開始,用3周時間,作下一個發佈計劃。」
在許多不成功的項目中,基本上都是隨意安排工做計劃,沒有任何的規律。那樣的隨機安排很難處理。你根本不知道明天將會發生什麼,也不知道什麼開始下一輪的全體「消防演習」。
可是敏捷項目會有一個節奏和循環,讓開發更加輕鬆。例如約定30天以內不該發生需求變化,這樣確保團隊有一個良性的開發節奏。這有助於防止一次計劃太多的工做和一些過大的需求變動。
咱們先來看某個工做日的狀況。你但願天天工做結束的時候,都能完成本身的工做,你手上沒有遺留下任何重要的任務。固然,天天都能這樣說不現實的。但你能夠作到天天下班離開公司前運行測試,並提交一天完成的代碼。若是已經很晚了,而且你只是嘗試性地編寫了一些代碼,那麼也許最好應該刪掉這些代碼,次日從頭開始。這個建議聽起來十分極端,但若是你正在開發小塊的任務,這種方式很是有助於你管理本身的時間:若是你工做的時候沒有一個固定的最終期限,就應該好好想一想了。
敏捷開發者能夠從多方面獲得反饋:用戶、團隊成員和測試代碼。但時間自己就是一個很是重要的反饋。
你可能不知道完成全部的任務須要多少個迭代,但每一個迭代必須是短時間的、有限的,而且要完成具體的目標。
迭代的時間是固定的,但在一個具體的迭代中完成哪些功能是靈活的。類似地,你會爲設計討論會設定時間期限,會議結束必需要作出最終的設計決策。
當你遇到艱難抉擇的時候,固定的時間期限會促使你作決定。你不能在討論或功能上浪費不少時間,這些時間能夠用於具體的工做。
站立會議最好天天在固定的時間和地點舉行,好比上午9點左右。要養成這樣的習慣,在那時就準備好一切參加站立會議。
最大的節拍就是迭代時間,通常是1~4周的時間。無論你的一個迭代是多長,都應該堅持——確保每一個迭代週期的時間相同很重要。運行有規律的開發節奏,會更容易達到目標,並確保項目不停地前進。
天使:「解決任務,在事情變得一團糟以前。保持事件之間穩定重複的間隔,更容易解決常見的重複任務。」