Java學習之路(書籍推薦)
前言:Java開發工程師一般負責後端開發,當然也有專門做Java Web的工程師,但是隨著前後端的分離,越來越多的Java工程師需要往大後端方向發展。今天我們就來介紹一下Java後端開發者的書單。首先要感謝一下某大佬力推的後端書架,初學階段讀到了很多好書直到現在都讓他印象深刻。
大佬說他在兩年的學習歷程中看了很多的書,其中不乏XXX入門到精通,XXX王者歸來,XXX指南什麼的。
雖然這類書確實毛病很多,但是作為非科班的他來說,當時還是看的津津有味。直到後來我他看到一些優秀的書籍,以及大佬的大佬哥的書架,他才逐漸認識到看一些精品書籍的好處。
所以我今天就從這些精品書籍中挑選一些優秀書籍來推薦給大家,當然其中有一些書我自己也沒有時間看完。
接下來我們按照後端技術棧各個部分的內容來推薦書籍。
懂的人自然懂吧,就不多說了,對了最後說一句,進了豬廠。
百度網盤
一共十二個系列整整50本電子書,找了好久終於齊了,如果都能看完看懂且科學的總結外加合理的實踐,相信BAT,TMD的Offer會向你招手的。
以下是每本書的推薦語,清楚自己缺的是什麼,就下定決心去補吧,一個好工作意味著高收入,投資自己的時間換來更寶貴的東西。
一.計算機網路系列:
1.《TCP/IP卷一》
這本其實我剛開始沒看太懂,可能是當時太水的原因,但是一般是大牛力薦的書。
2.《計算機網路:自頂向下》
這本從應用層講到物理層,感覺這種方式學起來更輕鬆,我比較推薦小白看這本。
3.《圖解HTTP和圖解TCP/IP》
相較於前兩本大厚書,這兩本書更加親民,小白可以買來看看,還是很適合入門的。
4.《計算機網路》
沒錯,就是這本教材,作為非科班選手自己看這本書,那叫一個欲仙欲死啊,看完就忘記了。
二.作業系統系列
1.《深入理解計算機系統》
這本書不是嚴格意義上的作業系統書籍,而是對計算機基礎和作業系統做了一個串聯,可以解決你很多對於計算機的疑惑,並且對作業系統有一定理解。
其實這本書還是很厚的,有一定難度,建議有一些基礎後再看。
2. 《現代作業系統》
這本書其實我沒怎麼看,比較詳細地講解了操作系,但是也是大家都比較推崇的書,還是那句話,很厚,慎看。
3.《Linux核心設計與實現》
當你對作業系統有一定理解以後,這本書將為你開啟學習Linux核心的大門,當然在此之前你得有一定的c語言開發能力,以及對Linux的瞭解。反正,我現在還沒開始準備好看這本書。
4.《Unix網路程式設計》
這兩本書的厚度絕對讓你感到絕望,其實就是講解了Unix核心是如何實現網路通訊的,其中涉及到很多網路,作業系統的知識,並且你要熟悉c語言。總之,這是一本奉為網路程式設計神書的存在,不過我等新手還是拿他壓壓泡麵就好了。網上有很多部落格會參照該書的內容,可以去看看它們。
三.資料結構與算法系列
不瞞你說,由於我非科班,所以演算法基礎比較差,資料結構是考研時跟著天勤考研指南學的,學習演算法也是一路坎坷,舉步維艱。還是分享幾本比較靠譜的書吧。
1.《演算法導論》
你問我是不是認真的,我就是說說而已,這本書我買來沒看過。
2.《資料結構與演算法(Java版)》
這本書對於初學者來說還是比較友好的,當然學Java的看這本。
3.《演算法圖解,啊哈演算法》
這兩部書籍非常適合學習演算法的入門,前者主要用圖解的形式覆蓋了大部分常用演算法,包括dp,貪心等等,可以作為入門書,後者則把很多常用演算法都進行了實現,包括搜尋,圖,樹等一些比較高階的常用演算法。
4 .《劍指offer》
這本書還是要強烈推薦的,畢竟是面試題經常參考的書籍,當然最好有前面基本的鋪墊再看,可能收穫更大,這本書在面試之前一般都要嚼爛。
5.LeetCode教科書式刷題網站
這不是一本書,是一個題庫,演算法麼,終究還是要靠刷題來提升熟練度的。
四.Java基礎系列
1.《Java程式設計思想》
這本書也是被譽為Java神書的存在了,但是對新手不友好,適合有些基礎再看,當然要選擇性地看。我當時大概只看了1/3
2.《Java核心技術卷一》
這本書還是比較適合入門的,當然,這種厚皮書要看完還是很有難度的,不過比起上面那本要簡單一些
五.Java進階系列
1.《深入理解JVM虛擬機器》
這本書是Java開發者必須看的書,很多jvm的文章都是提取這本書的內容。JVM是Java虛擬機器,賦予了Java程式生命,所以好好看看把,我自己就已經看了三遍了。
2.《Java併發程式設計實戰》
這本書是Java 併發包作者寫的書,所以非常權威,但是比較晦澀難懂,我看的雲裡霧裡的,大家可以按需選擇。
3.《Java併發程式設計藝術》
這本書是國內作者寫的Java併發書籍,比上面那一本更簡單易懂,適合作為併發程式設計的入門書籍,當然,學習併發原理之前,還是先把Java的多執行緒搞懂吧。
4.《Effective Java》
這本書和Java程式設計思想一樣被稱為神書,主要講的是Java的一些優化技巧和規範,沒有一定開發經驗的人看這本書會覺得索然無味,不知所云,所以,先擱著吧。
5.《Java效能調優指南》
說到JVM調優,可能會有很多的面試題浮現在你的腦海裡,這本書比較權威地講解了Java的效能調優方法,不過我還沒怎麼看,有空好好看看。
6.《 Netty權威指南》
Netty是基於NIO開發的網路程式設計框架,使用Java程式碼程式設計,其實這本書也可以放在網路或者Java Web部分。不過NIO屬於JDK自帶的一部分,是必須要掌握的,而對於Netty,大家如果學有餘力的話也可以看看。
六.JavaWeb系列
1.《深入JavaWeb技術內幕》
這本書是Java Web的集大成之作,涵蓋了大部分Java Web開發的知識點,不過一本書顯然無法把所有細節都講完,但是作為Java Web的入門或者進階書籍來看的話還是很不錯的。
2.《How Tomcat Works》
Java Web很重要的一部分內容就是Tomcat,作為應用伺服器,Tomcat使用Java開發,其原始碼和架構設計都是經典之作。
這是一本講解Tomcat基本原理的書籍,很好地通過剖析原始碼來講解Tomcat的內部結構和執行機制,但是需要一定的基礎才能夠看懂,我還沒看這本書,日後再拜讀。
2.《Tomcat架構解析》
和上面這本書類似,主要講解Tomcat原理和架構,,要看懂這本書的話,前提是你要對Java基礎,NIO以及設計模式有所瞭解。這本書我也還沒看。
3.《Spring實戰》
這本書適合作為Spring的入門書籍,把Spring的概念,使用方式等內容都講的比較清楚。並且也介紹了Spring MVC的部分內容,Spring框架還是更注重實踐的,所以跟著書上的內容去做吧。
4.《Spring原始碼深度解析》
學會Spring基礎後,可以花點時間看看這本講原始碼的書了,這本書對於新手來說不太友好,主要也是因為Spring的程式碼結構比較複雜,大家也可以看一些部落格來完成對原始碼的學習。
5.《Spring MVC學習指南》
本書是一本Spring MVC的教程,內容細緻、講解清晰,非常適合Web開發者和想要使用Spring MVC開發基於Java的Web應用的讀者閱讀。但是由於出的比較早,所以不太適合現在版本。
6.《Maven實戰》
Maven是Java Web開發中不可缺少的一部分,如果想要全面瞭解其實現原理的話,可以看看這本書。
七.資料庫系列
1.《資料庫原理》
資料庫原理應該是教材吧,這本書作為資料庫入門來說還是可以的,畢竟不是專門做DB的,看大厚書用處不大,這本書把資料庫的基本概念都講完了。
2.《SQL必知必會》
這本書主要是講解sql語句怎麼寫,畢竟資料庫最重要的一點就是要熟練地使用sql語句,當然這本書也可以當做工具書來使用。
3.《深入淺出MySQL》
這本書適合作為MySQL的學習書籍,當你有了一定的MySQL使用經驗後,可以看看它,該書從資料庫的基礎、開發、優化、管理維護和架構5個方面對MySQL進行了詳細的介紹,講的不算特別深,但是足夠我們使用了。這本書我也只看了一部分。
4.《MySQL技術內幕:innodb儲存引擎》
看完上面那本書以後,對MySQL算是比較熟悉了,不過對於面試中常考的innodb引擎,還是推薦一下這本書把,專門講解了innodb儲存引擎的相關內容。我還沒有細看,但是內容足夠你學好innodb了。
5.《高效能Mysql》
這本書可以說是很厚了,更適合DBA拜讀,講的太詳細了,打擾了。
6.《Redis實戰》
和MySQL一樣,學習Redis的第一步最好也是先實戰一下,通過這本書就可以較好地掌握Redis的使用方法,以及相關資料結構了。
7.,《Redis設計與實現》
該書全面而完整地講解了 Redis 的內部執行機制,對 Redis 的大多數單機功能以及所有多機功能的實現原理進行了介紹。這本書把Redis的基本原理講的一清二楚,包括資料結構,持久化,叢集等內容,有空應該看看。
八.分散式系列
1.《分散式Java應用》
這本書是淘寶大牛寫的書,主要講的就是使用rpc來構建分散式的Java應用,講了很多基礎的東西,可以作為入門書籍,不過這本書我之前沒有遇到,所以沒看過。
2.《大型網站技術架構》
這本淘寶系技術指南還是非常值得推崇的,可以說是把大型網站的現代架構進行了一次簡單的總結,內容涵蓋了各方面,主要講的是概念,很適合沒接觸過架構的同學入門。看完以後你會覺得後端技術原來這麼博大精深。
3.《大型分散式網站架構設計與實踐》
這本書與上面一書相比更傾向於實踐,主要講的是分散式架構的一些解決方案,但是如果你沒有接觸過相關的場景,可能會看的雲裡霧裡。
4 .《布式服務框架原理與實踐》
上面那本書講的是分散式架構的實踐,而這本書更專注於分散式服務的原理講解和對應實踐,很好地講述了分散式服務的基本概念,相關技術,以及解決方案等,對於想要學習分散式服務框架的同學來說是本好書。
5.《大型網站系統與Java中介軟體開發實踐》
話說這些書的名字真實夠長的。這本書也是阿里系出品,主要講的是大型網站系統以及使用的相關中介軟體,畢竟阿里是中介軟體大戶,所以很多中介軟體對應用再網站系統中,對於想學習這方面技術的同學來說可以一看。
6.《從Paxos到Zookeeper分散式一致性原理與實踐》
說起分散式系統,我們需要了解它的原理,相關理論及技術,這本書也是從這個角度出發,講解了分散式系統的一些常用概念,並且帶出了分散式一哥zookeeper,可以說是想學分散式技術的同學必看的書籍。
7.《大規模分散式儲存系統》
這本書是阿里巴巴oceanbase核心開發大佬寫的書,講的是分散式儲存相關的原理和解決方案,該書不是很厚,如果想做儲存方向的同學可以看看。
九.雲端計算系列
雲端計算方面的內容主要是我在實習階段接觸的,如果只是應用開發方向的話這塊不懂也罷。主要還是看個人興趣。
1.《OpenStack設計與實現》
OpenStack是基於KVM技術的一套私有云生態。這本書很好地講解了OpenStack的一些基本原理,包括各個元件的設計與實現,比起另一本《OpenStack王者歸來》簡單易懂的多。當然,前提最好是你對Linux核心和網路有所瞭解。
2.《docker入門與實踐》
docker是現在應用部署的主流方案了,所以瞭解一下還是挺有必要的,這本書作為入門書籍足夠讓你會使用docker了。
3.《Kubenetes權威指南》
kubenetes是docker的叢集解決方案,也是一個微服務的解決方案,所以這本書涉及的內容非常多,需要有網路,作業系統以及docker相關的基礎。我看這本書的時候可以說是非常暈的。
十.大資料系列
和雲端計算一樣,大資料方面的內容也不算是Java後端技術棧所需要的,但是這也能為你加分,並且讓你跟大資料開發的崗位沾點邊,何樂而不為。
1《大資料技術原理與應用》
作為大資料方面的一本教材,廈大教授寫的這本書還是非常讚的,從最基礎的原理方面講解了Hadoop的生態系統,並且把每個元件的原理都講得比較清楚,另外也加入了spark,storm等內容,可以說是大資料入門非常好的一本書了。
2.《Hadoop實戰》
這本書很厚,我買的時候大概看了一遍,一頭霧水。所以建議先看上面那本書,再來看更加進階的書籍,否則可能就是浪費時間了。
3 《Hadoop權威指南》
這本書主要對Hadoop生態中元件進行詳細講解,有點太詳細了,如果不是做大資料方向的話,可以不看。
十一.其他系列:
1 《Git權威指南》
Git是現在大公司主流的程式碼協同工具,如果你想要了解其底層原理,可以看看這本書。
2 《重構——改善既有程式碼的設計》
這本書主要介紹的是程式碼重構的一些指導思想和最佳實踐。有重構需求的同學可以看看。
3 .其他的其他
其他方面的書籍就太多了,比如軟體工程方面的,測試方面,Linux方面,以及講一些程式設計師自我提升的書籍,就不一一列舉了,因為這部分的內容可以不歸入Java後端的技術棧。
十二.頸椎康復系列:
1 《做自己的頸椎醫生》
總結一下:
一.計算機網路系列(4本):
1.《TCP/IP卷一》 2.《計算機網路:自頂向下》
3.《圖解HTTP和圖解TCP/IP》 4.《計算機網路》
二.作業系統系列(4本)
1.《深入理解計算機系統》 2. 《現代作業系統》
3.《Linux核心設計與實現》 4.《Unix網路程式設計》
三.資料結構與算法系列(4.5本)
1.《演算法導論》 2.《資料結構與演算法(Java版)》
3.《演算法圖解,啊哈演算法》 4 .《劍指offer》
5.LeetCode教科書式刷題網站
四.Java基礎系列(2本)
1.《Java程式設計思想》 2.《Java核心技術卷一.二》
五.Java進階系列(6本)
1.《深入理解JVM虛擬機器》 2.《Java併發程式設計實戰》
3.《Java併發程式設計藝術》 4.《Effective Java》
5.《Java效能調優指南》 6.《 Netty權威指南》
六.JavaWeb系列(7本)
1.《深入JavaWeb技術內幕》 2.《How Tomcat Works》
3.《Tomcat架構解析》 4.《Spring實戰》
5.《Spring原始碼深度解析》 6.《Spring MVC學習指南》
7.《Maven實戰》
七.資料庫系列(7本)
1.《資料庫原理》 2.《SQL必知必會》
3.《深入淺出MySQL》 4.《MySQL技術內幕:innodb儲存引擎》
5.《高效能Mysql》 6.《Redis實戰》
7.《Redis設計與實現》
八.分散式系列(7本)
1.《分散式Java應用》 2.《大型網站技術架構》
3.《大型分散式網站架構設計與實踐》 4 .《布式服務框架原理與實踐》
5.《大型網站系統與Java中介軟體開發實踐》 6.《從Paxos到Zookeeper分散式一致性原理與實踐》
7.《大規模分散式儲存系統》
九.雲端計算系列(3本)
1.《OpenStack設計與實現》 2.《docker入門與實踐》
3《Kubenetes權威指南》
十.大資料系列(3本)
1《大資料技術原理與應用》 2.《Hadoop實戰》
3 《Hadoop權威指南》
十一.其他系列(2本)
1 《Git權威指南》 2 《重構——改善既有程式碼的設計》
3 .其他的其他
十二.頸椎康復指南系列(不開玩笑,適當看看真心有用)(1本)
1.《做自己的頸椎醫生》
百度網盤