首頁>Club>
6
回覆列表
  • 1 # lao許—搞笑研究院

    牛逼的方法論

      

    1)編碼

      毫無疑問,你必須得編碼,持續不斷地編碼,要達到一定的量。

      量變會引起質變,但不是必然。

      持續編碼的結果有兩個,一個是達到質變,水平不斷提升;一個是重複重複再重複最終麻木。要哪個?

    2)回顧與思考

      要想質變與提升,必須有目的地停下編碼!只編碼,不走心,那是萬萬不行的。不走心的程式設計師很多,幹多少年了水平還和初干時差不多,十年如一日。走心就不一樣,走心一日如十年。

      我們要週期性的回顧自己,看看以前的程式碼,分析下現在的設計,看看哪些可以改善,有多少種改善思路……這樣就能看出以前的自己與現在的自己這兩者之間的差距。如果你覺得自己以前的程式碼是翔,那恭喜你,你絕對提升了不少。

      要回顧以前,還要分析現在。程式設計師還要經常梳理一下自己的狀態,看看我現在都掌握了什麼技能,在哪些方向和領域有所成就,再加上對過去的回顧,看看哪些是延續性的前進,哪些是無心插柳,哪些是冤枉路,哪些是意外之喜。這樣就會對自己的能力邊界有所瞭解,知道自己知道什麼,也知道自己不知道什麼,更重要的是,你會發現自己能把什麼東西學好用好,還能發現自己為什麼可以把這些東西學好,那樣你就可以找到自己擅長的方向,做得更好。

      回顧了以前,分析了現在,還要想想將來。在技術上,我要在哪些方向繼續前行深入挖掘?這點非常重要。我們佇立現在,回首過去,仰望未來,這是上山的姿勢啊。哈哈,上山好啊,值得期待的只有前方。

      作為有追求的程式設計師,我們不必這樣擔心吧。只管積累我們的 10000 小時去,只管思考如何有效地利用這 10000 小時去,不但過程是美麗的,將來也會是美麗的。

    3)多學一點點

      臺上一分鐘,臺下十年功。那些牛逼的程式設計師,無一不是付出了比普通程式設計師更多的精力。

      我們在開發時,會接觸各種各樣的新技術。有時因為專案時間原因,很多技術只能是走馬觀花的用,解決問題為目的,專案結束了可能就扔一邊兒去了。但要想讓自己有更大的成長,那我們就應該學多一點,用一分學兩分,廣裡一分,深裡一分,不能不求甚解一帶而過。對於用過的技術,最好在當時,專案的間隙或者專案結束時,抽時間瞭解它的背景、長處、機理,讓自己對用到的技術都有相當程度的瞭解。惟其如此,我們的知識面和技術深度,才會隨著開發經驗而不斷遞進。

    4)實踐新技術

      選擇或者學習一門新的技術,必須要實踐。可以把它應用到工作中的專案,如果工作條件限制,那也要自己定義一個自己喜歡的專案,堅持使用你的新技術做下來。唯有實踐,你的新技術才能理解得更為深刻。知道有那麼一門技術,與實際使用過,其間的差異可不止一點。

    5)溝通

      很多人覺得程式設計師比較難溝通,說程式設計師不會好好說話……你覺得呢?

      我想說的是:要想成為牛逼的程式設計師,溝通一定要過硬!

      程式設計師是幹嘛的?不是寫程式碼的,而是解決問題的。

      解決問題才是程式設計師的職責。

      要解決問題,離不開溝通。

      客戶會找你,市場會找你,產品經理會找你,UI設計師會找你,開發同事會找你,測試妹妹會找你,老闆也會找你,女盆友會因為你的投入與執著愛上你也會在愛上你後因為這些而不斷與你爭執……

      哪一樣離得開溝通呢?

      當然我不是說程式設計師要像銷售、市場、營銷等等崗位的兄弟姐妹們一樣妙語生花,其實溝通最重要的是能聽懂別人說什麼,能把你想說的以對方能理解的方式說出來。至於是妙語連珠還是磕磕絆絆,是語言溝通、眼神溝通還是書面溝通,只要達到目的即可。

      有人說我天生不愛說話,跟機器打交道才覺得踏實。其實這沒關係,你要找到自己的溝通方式,看怎樣才能讓別人理解,也調整自己的聆聽和理解方式,看怎樣才能理解別人說的話。

      怎樣才能讓別人正確理解你的話,怎樣你才能正確聽懂別人的話,這都需要不斷的學習、練習,這方面有很多的書啊影片啊,可供參考。這沒什麼不好意思的啊,我認識一些朋友,覺得學習說話技巧是很不好意思的一件事兒,好像這樣做就說明自己心懷鬼胎就多丟人似的。其實不必,我們的目的不是巧舌如簧地騙取別人的信任然後來謀取利益,我們的目的很簡單,就是讓別人理解我們也讓自己理解別人。

    6)理解溝通模型

      溝通這事兒真是一門學問,雖然我在這方面一向魯鈍,還是想以我們程式設計師的方式,打個比方來說明一下溝通模型。

      首先每個人心裡都有一個 TCP Server ,監聽到某個埠上,等待陌生人或者熟人或者半生不熟的人來訪問。

      其次呢,不同的人對自己的埠是否開放持不同的態度,OPEN的人就會監聽到知名埠,比如80、21、7、13、22、23等等,這樣別人就知道我們找這個 OPEN 的傢伙說事兒該連線哪個埠。當然,只開放埠還不夠,靈慧的人還會慢慢把自己的協議 SHOW 給別人,這樣想找他聊天的人就可以遵循這個協議來說,事情就容易多了,雙方就都能理解。還有一些人呢,比較內斂,雖然內心很飢渴,希望別人找自己聊聊天談談心,可是不知道怎麼把自己的埠開放給別人,或者出於某種原因隱藏了埠。比如他本來是監聽到 21 埠上,走 FTP 協議,因為被別人透過埠掃描的方式黑了兩次受了點不大不小的傷害,就小心地封掉了 21 埠,把自己的服務挪到了其它埠上,並且也不告訴別人。這就出問題了,別人找不到埠號,怎麼和你溝通咧……還有一些人呢,自己也不知道該監聽到哪個埠上,不能有意識的訓練自己,今天是 21 ,明天就 80 ,後天又走 37 了,結果不但自己混亂,跟他打交道的兄弟姐妹們也混亂:昨天這麼說還挺融洽,今天再這麼說他居然翻臉了呢!這是我們每個人內心的 TCP Server 。其實每個人還有一個 UDP Server ,是為那些夾生的人或者擁有特別標籤的人準備的。你可以知道我的 UDP 埠,但是你發訊息過來我就不一定搭理你,被拆穿了我還可以說 UDP 協議不可靠,我沒收到……。這兩個 Server 就是我們每個人身上基本的溝通模型。

      最後呢,如果你要想向別人說明你的意圖並讓別人按你的意圖去做某件事,那就要花費精力去研究如何找到對方監聽的埠、使用的協議。和 OPEN 的人溝通比較容易,訪問 80 埠,走 HTTP 就行了,或者夜半三更翻牆過去幽會也能成。而針對那些隱藏了埠和協議的,就要啟用埠掃描這種神器,掃到埠,再抓包分析協議,成功的可能性總是有的,只不過費些力氣罷了。

    用這種模型來解釋現實生活中的溝通問題,程式設計師們就可以釋然了:啊哈,原來我給他說的事兒他老不反應,是搞錯了埠或者走錯了協議。

    7)表達自己

      理解了溝通模型,找到了對方的埠和協議,還有一個問題需要解決:你怎麼準確地表達你的意圖。

      對於相當一部分程式設計師,這是個難題。有的人本身就寡言少語(我是這類的);有的人很厲害,與別人說話時腦子轉得比別人快幾倍,腦子裡轉的是長長的帶上下文的句子,從嘴裡出來後就成了嘎嘣脆的詞語,還以為自己說過了別人都能理解;有的人寫程式碼一二三四條理清楚,說話時就比較發散,正說股票呢忽然就轉到APEC藍上了;有的人比較羞澀,大男人說話卻聲若蚊蠅……總之各類情況都有,你見到的絕對比想到的多。

      不管你屬於哪一類,要想能順暢地與人溝通,先要訓練自己,讓自己可以準確地表達。

      我是不會表達的人呢,你看我洋洋灑灑長文千字,其實我不大會說話。不過我要說的是:如果你說不好,那就想辦法先寫好。

      “寫”這個事情,比說更容易讓人條理清楚,因為寫這個過程時間相對寬鬆,上下文簡單,不像與人溝通那樣你來我往還要時刻注意話外音整個過程比較複雜。所以,寫,是一個很好的鍛鍊自我表達的手段。寫作能訓練你表達的準確度。

      你可以透過寫部落格,寫日誌等等手段,把自己的想法表達出來。然後呢,過一段時間,你能透過寫作來表達自己的了,再回頭來影響說話,你把嘴上說的當作紙上寫的,多練習練習,就能準確的表達自己的意圖了。你看人家領導人講話還需要先打打草稿呢不是,更甚之的還有念稿子的。

    因為我也要向這個方向發展

  • 2 # 莫莫嘮嗑

    要成為很牛的程式設計師,應該做到下面幾點

    1.程式碼積累

    程式碼量的多少能看出你有多用心,而且做一個小專案也是讓你對程式碼更加的熟練,在專案時更好的拿出來用。

    2.問題積累

    把你在程式設計中遇到的問題專門記錄在一個小本本上,等下次再遇到這問題,就能溫故而知新了。

    3.時間處理

    時間這塊, 每天起碼拿出5-6個小時放在程式設計上,如果特別積極,可以學習8-9個小時。

    4.自主學習與方法學習

    要成為很牛的程式設計師,也要做到自主學習。自己學習就像是自己在慢慢摸索中前進,而進入公司做專案就是比較快的一個成長方式,但還是離不開自主學習。這個其實是最為重要的。而且做很牛的程式設計師方法也是很重要的,把側重點放準,效率才會提高。

    5.不輕言放棄

    做一件事就要認真對待,不能隨隨便便就說放棄,碰到難題,就要用心去解決,別把問題丟在那就不管了,只要不輕言放棄,成為一個很牛的程式設計師還是可以做到的。

  • 中秋節和大豐收的關聯?
  • 蘋果樹能追尿素嗎對樹有影響嗎?