給各階段java學習者的建議[轉]

第一部分:
零基礎或基礎薄弱的同窗
這部分主要適用於還沒有作過Java工做的同窗,包括一些在校生以及剛準備轉行Java的同窗。
1、Java基礎
首先去找一個Java的基礎教程學一下,這裏能夠推薦達內java課程,或者你也能夠去找相應的視頻。
學習Java基礎的時候,應該儘可能多動手,不少時候,你想固然的事情,等你寫出來運行一下,你就會發現不是這麼回事兒,不信你就試試。
學完以上內容之後,你應該對Java有一個基本的瞭解了,你能夠用Java語言寫出一些簡單的程序,而且你用的是最簡單的編輯器,好比記事本。
這個時候,不要急於進入下一部分,留下幾天好好寫一些程序,儘量熟悉這些基礎內容。
2、Web開發
等你寫上幾天程序之後,你每每會比較迷茫,由於你寫的東西彷佛看起來毫無用處,好比實現一個簡單的計算器,讀取一個文件等。這個時候你就應該去學着寫一些讓你以爲有意思的東西了,因此你應該學習更多的知識。
這些內容主要是Web開發相關的內容,包括HTML/CSS/JS(前端頁面)、Servlet/JSP(J2EE)以及Mysql(數據庫)相關的知識。
它們的學習順序應該是從前到後,所以最早學習的應該是HTML/CSS/JS(前端頁面),這部份內容你能夠去上面的那個runoob網站上找。你能夠試着本身寫一些頁面,固然,你能夠盡你最大的努力讓它變得最漂亮。這部份內容對於後端Java來講,理論上不是特別重要,但至少要達到能夠本身寫出一些簡單頁面的水平。
接下來,你須要學習的是Servlet/JSP(J2EE)部分,這部分是Java後端開發必須很是精通的部分,所以這部分是這三部分中最須要花精力的,並且這個時候,你要學會使用開發工具,而不能再使用記事本了,能夠選擇eclipse。
當你下載安裝好eclipse之後,跟着視頻中的教程一步一步去學習,必定要多動手。
最後一步,你須要學會使用數據庫,mysql是個不錯的入門選擇,並且Java領域裏主流的關係型數據庫就是mysql。這部分通常在你學習Servlet/Jsp的時候,就會接觸到的,其中的JDBC部分就是數據庫相關的部分。你不只要學會使用JDBC操做數據庫,還要學會使用數據庫客戶端工具,好比navicat,sqlyog,二選一便可。
3、開發框架
當你學會以上內容之後,這個時候你還不足以參加工做,你還須要繼續深造。公司裏爲了提升開發的效率,會使用一些Java Web框架,所以你還須要學習一些開發框架。
目前比較主流的是SSM框架,即spring、springmvc、mybatis。你須要學會這三個框架的搭建,並用它們作出一個簡單的增刪改查的Web項目。你能夠不理解那些配置都是什麼含義,以及爲何要這麼作,這些留着後面你去了解。但你必定要能夠快速的利用它們三個搭建出一個Web框架,你能夠記錄下你第一次搭建的過程,相信我,你必定會用到的。
還要提一句的是,你在搭建SSM的過程當中,可能會常常接觸到一個叫maven的工具。這個工具也是你之後工做當中幾乎是必需要使用的工具,因此你在搭建SSM的過程當中,也能夠順便了解一下maven的知識。在你目前這個階段,你只須要在網絡上了解一下maven基本的使用方法便可,一些高端的用法隨着你工做經驗的增長,會逐漸接觸到的。
4、找工做
當你完成開發框架的學習之後,你就該找工做了,在校的找實習,畢業的找全職。與此同時,在找工做的同時,你不該該停下你的學習,準確的說,是你在之後都不能停下學習。
上面這些內容你只是囫圇吞棗的學會了使用,你能夠逐步嘗試着去了解更多的東西,網絡是你最重要的老師。
第二部分:
對於參加工做一年之內的同窗
恭喜你,這個時候,你已經擁有了一份Java的工做。這個階段是你成長極快的階段,並且你可能會常常加班。
可是加班不表明你就能夠鬆懈了,永遠記得我說的那句話,從你入行那一刻起,你就要不停的學習。在這一年裏,你至少須要看完《Java編程思想》這本書。這本書的內容是幫助你對於Java有一個更加深刻的瞭解,是Java基礎的升級版。
這本書很厚,當初看這本書,我花了整整三個月。正常速度的話,應該能夠在半年左右看完。我這裏不要求太高,只要你在一年之內把這本書看完便可。固然了,我所說的看完,是充分吸取,而不是讀一遍就完事了,所以有些內容你可能會看不止一遍。
總而言之,這個階段的核心學習思想就是,在工做中實踐,而且更加深刻的瞭解Java基礎。
第三部分:
對於參加工做1年到2年的同窗
這部分時間段的同窗,已經對Java有了一個更加深刻的瞭解。可是對於面向對象的體會可能還不夠深入,編程的時候還停留在完成功能的層次,不多會去考慮設計的問題。
因而這個時候,設計模式就來了。我當時看的是《大話設計模式》這本書,而且寫了完整版的設計模式博客。所以,我要求你們,最多在你工做一年的時候,必須開始寫博客,而設計模式就是你博客的開端。
這一年,你必須對於設計模式瞭如指掌,《大話設計模式》能夠做爲你的開端。
此外,設計模式並非你這一年惟一的任務,你還須要看一些關於代碼編寫優化的書。好比《重構 改善既有代碼的設計》,《effective java》。
總而言之,這個階段,你的核心任務就是提升你的代碼能力,要能寫出一手優雅的代碼。
第四部分:
對於參加工做2年到3年的同窗
有的同窗在這個時候以爲本身已經很牛逼了,因而忍不住開始慢慢鬆懈。請記住,你還嫩的多。
這個階段,有一本書是你必須看的,它叫作《深刻理解Java虛擬機》。這本書絕對是Java開發者最重要的書,沒有之一。在我眼裏,這本書的重要性還要高於《Java編程思想》。
這本書的內容是幫助你全面的瞭解Java虛擬機,在這個階段,你必定已經知道Java是運行在JVM之上的。因此,對於JVM,你沒有任何理由不瞭解它。我以前有寫過JVM系列的知識,能夠去看一下。
另外,在過去2年的工做當中,你確定或多或少接觸過併發。這個時候,你應該去更加深刻的瞭解併發相關的知識,而這部份內容,我比較推薦《Java併發編程實戰》這本書。只要你把這本書啃下來了,併發的部分基本已經瞭解了十之六七。
與此同時,這個階段你要作的事情還遠不止如此。這個時候,你應該對於你所使用的框架應該有了更深刻的瞭解,對於Java的類庫也有了更深刻的瞭解。所以,你須要去看一些JDK中的類的源碼,也包括你所使用的框架的源碼。
這些源碼能看懂的前提是,你必須對設計模式很是瞭解。不然的話,你看源碼的過程當中,永遠會有這樣那樣的疑問,這段代碼爲何要這麼寫?爲何要定義這個接口,它看起來好像不少餘?
由此也能夠看出,這些學習的過程是環環相扣的,若是你任何一個階段拉下來了,那麼你就真的跟不上了,或者說是一步慢步步慢。並且我很負責的告訴你,我在這個階段的時候,所學習的東西遠多於這裏所羅列出來的。所以千萬不要以爲你已經學的不少了,我所說的這些都只是最低要求,不光是我,不少人在這個時間段所學習的內容都遠超本文的範圍。
若是你不能跟上節奏的話,若干年後,若是不是程序猿市場還不錯的話,你極可能不只僅是工資比別人低,公司沒別人好,而是根本就找不到工做。
總而言之,這個階段,你須要作的是深刻了解Java底層和Java類庫(好比並發那本書就是Java併發包java.concurrent的內容),也就是JVM和JDK的相關內容。並且還要更深刻的去了解你所使用的框架,方式比較推薦看源碼或者看官方文檔。
另外,還有一種學習的方式,在2年這個階段,也應該啓用了,那就是造輪子。
不要聽信那套「不要重複造輪子」的論調,那是公司爲了節省時間成本編造出來的。一個造輪子的過程,是一個從無到有的過程。這個過程能夠對你進行系統的鍛鍊,它不只考察你的編碼能力,還考察你的框架設計能力,你須要讓你的輪子擁有足夠好的擴展性、健壯性。
因此,這個階段,除了上面提到的瞭解JVM、JDK和框架源碼之外,也請你根據別人優秀的源碼,去造一個任何你可以想象出來的輪子。
第五部分:
參加工做3年到4年的同窗
這個階段的同窗,提高已是很難了,並且這個階段的學習每每會比較多樣化。
由於在前3年的過程當中,你確定或多或少接觸過一些其它的技術,好比大數據、分佈式緩存、分佈式消息服務、分佈式計算、軟負載均衡等等。這些技術,你能精通任何一項,都將是你將來面試時巨大的優點,所以若是你對某一項技術感興趣的話,這個時候能夠深刻去研究一下。這項技術不必定是你工做所用到的,但必定是相關的。
並且在研究一門新技術時,切忌朝秦暮楚。有的同窗今天去整整大數據,搞搞Hadoop、hbase一類的東西。過不了一段時間,就以爲沒意思,又去研究分佈式緩存,好比redis。而後又過不了一段時間,又去研究分佈式計算,好比整整Mapreduce或者storm。
結果到最後,搞得本身好像什麼都會同樣,在簡歷上大言不慚的寫上大數據、分佈式緩存、分佈式計算都瞭解,其實任何一個都只是浮於表面。到時候面試官隨便一問,就把你給識破了。
所以在這個階段,你就不能再簡單的去學習前3年的內容了,雖然前面的學習若是還不夠深刻的話依舊要繼續,但這個時候你應該更多的考慮創建你的優點,也能夠稱爲差別性。你前面三年的學習足夠你成爲一名基本合格的Java開發者,但你離成爲一名優秀的Java開發者還有很大的距離。
爲了讓本身有差別性,你就須要另闢蹊徑,找一個方向深刻研究下去,以期在未來,你可以成爲這個領域的專家,好比分佈式計算領域的專家,大數據領域的專家,併發領域的專家等等。
此外,你除了創建你的差別性以外,還要去彌補你基礎上的不足,若是你的基礎原本就很是強,那麼恭喜你,相信你在以前的工做中已經充分體會到了這些基礎對你的幫助。但我相信大部分人的基礎都很薄弱,哪怕是科班畢業的人,不少人也不敢說本身當初的基礎學的多麼強大,好比算法、計算機系統原理、編譯原理這些。
首先,我比較推崇的基礎書籍有三本,分別是《深刻理解計算機系統》,《tcp/ip詳解 卷1、2、三》,《數據結構與算法》。其中TCP/IP有三本書,但咱們這裏把這三本當作是一本大書。
這三本分別適合三種人,《深刻理解計算機系統》比較適合一直從事Java Web開發和APP後端開發工做的人羣。《tcp/ip詳解 卷1、2、三》比較適合作網絡編程的人羣,好比你使用netty去開發的話,那麼就要對TCP/IP有更深刻的瞭解。而《數據結構與算法》這本書,則比較適合作計算研究工做的人,好比剛纔提到的分佈式計算。
理論上來說,這一年你能把這三本其中一本精讀下來,就已經很是厲害了。有了基礎,有了前面的工做經驗,你就能夠去開拓屬於你的領域了。
第六部分:
參加工做4年到5年的同窗
通過前面幾年的歷練,相信你在本身所鑽研的領域已經有了本身必定的看法,這個時候,技術上你應該已經遇到瓶頸了。
這個時候不要着急提升本身的技術,已是時候提升你的影響力了,你能夠嘗試去一些知名的公司去提升你的背景,你能夠發表一些文章去影響更多的人。固然,你也能夠去Github建立一個屬於你的開源項目,去打造本身的產品。此次的開源項目不一樣於以前的造輪子,你這個時候是真的要去儘可能嘗試造出來真正對別人有價值的輪子。
這個時候提升影響力不只僅是由於技術上容易遇到瓶頸,更多的是影響力能夠給你創造更多的機會。程序猿在某種程度上和明星很像,一個好的電視劇和電影就能夠成就一批明星,程序猿有的時候也是,一個好的項目就能夠成就一羣程序猿。
好比國內幾個膾炙人口的項目,像淘寶、支付寶、QQ、百度、微信等等。這每個項目,都成就了一批程序猿。我敢說,這裏面任何一個項目,若是你是它的核心開發,光是這樣一個Title,就已是你很是大的優點。更況且還不止如此,Title說到底也是個名頭,更重要的是,這種項目在作的時候,對你的歷練必定也是很是給力的。
而你若是想要參與這樣的項目,除了靠運氣以外,影響力也是很重要的一個手段。好比你在分佈式計算領域有必定的影響力,那麼若是有什麼好的關於分佈式計算的項目,對方就極可能會邀請你。就算人家不邀請你,你本身主動去面試的時候,對方若是知道你在這個領域的影響力,也確定會起到很大的做用,而這個做用,甚至可能會超過你如今的技術能力。
因此,在這個階段,你最大的任務是提升本身的影響力,爲本身將來的十年工做生涯那一天作準備。若是你可以靠你的影響力和之前積累的技術,參與到一個偉大的項目當中,那麼你後面的五年也就有着落了。
但願本文能夠幫助到做爲程序猿或即將成爲程序猿的你。前端

相關文章
相關標籤/搜索