java管理系統(tǒng)入門教學 如何系統(tǒng)的學習JAVA?
如何系統(tǒng)的學習JAVA?java的整體生態(tài)和學習積累確實是太大了。95年至今20多年的積累,完全涉及到計算機軟硬件的方方面面。我暫且放過就以為,提主所說的精通滿,是指jdk本身和一些必要的數(shù)據結構以及
如何系統(tǒng)的學習JAVA?
java的整體生態(tài)和學習積累確實是太大了。95年至今20多年的積累,完全涉及到計算機軟硬件的方方面面。我暫且放過就以為,提主所說的精通滿,是指jdk本身和一些必要的數(shù)據結構以及廣泛框架和面向對象的基本是思想吧。
從11年初至今,一直在學習java相關的知識。其中也走了不少彎路。按自己的積累,能提供提主一個自認為比較合理且有一定深度的學習路線。大概情況分下面幾個階段吧。
1.是需要應盡可能的打牢基礎的數(shù)據結構和簡單的算法基礎。
可以不去迅速的學習一些簡單的大型系統(tǒng),來滿足的條件軟件怎么學習的興趣和初期成就感。但,要先回過身,翻看的平定內亂數(shù)據結構基礎和簡單算法。像這種書就可以不。
2.能熟練在用Java類庫和java第三方工具框架。
學習不使用java的語法,嘗試明白Java語法怎么設計的邏輯。熟練掌握到jdk開發(fā)庫本身,這些各種第三方類庫工具包和第三方框架的簡單的使用。這里怎么學習的同時,推薦看看吧《設計模式》,《代碼整潔之道》,《spring源碼解讀》,《Spring揭秘》等這一類的書集。
3.理解怎么學習jdk類庫本身的應用源碼實現(xiàn)方法和高端點第三方框架的源碼和架構設計。
例如jdk本身的數(shù)據結構二叉樹,紅黑樹,treemap,和異步包的unsafe,同步阻塞隊列,call-future等等包源碼,以及線程基礎類的實現(xiàn),各個類庫啊,設計的結構和設計模式。理解透徹第三方框架的設計思想,理解學習第三方框架的核心源碼。
肯定,這里面很可能會涉及到其他的事務,分布式協(xié)議等,這里繼續(xù)發(fā)起。這個過程未必一朝一夕,可能會要大量的時間和技術感悟。當然了,《設計模式》,《代碼整潔之道》,《spring源碼解讀與設計詳析》,《Spring揭秘》等等這一大類書,在這個過程可以不解釋大差不差了。
4.理解jdk,jre即jvm原理和實現(xiàn)方法。
這里我?guī)臀彝扑]看下葛老師的《實戰(zhàn)java虛擬機》,里面解釋比較好偏實操。容易上手理解。
首先,可以不從jdk光盤驅動的工具去學習來從哪里入手。
.例如:jstat,jmap,jstack,jps,jdb.......甚至連還有一個直接這個可以窺視運行期間求實際內存數(shù)據的HSDB。當然了,充當學習進一步,我們只必須表述正確的幾個命令,并知道其代表的意義再試一下。畢竟,第三方監(jiān)控工具,包括jdk本身也提供給了3個可視化的監(jiān)控。
如果你是,再理解jvm的運行打開程序原理,搞懂class文件結構。
這個過程我們可以借助于之前會用的監(jiān)控工具,理解jvm讀取的基本原理。可以建議參考官方各個版本的jvm標準,學習看懂class文件。到此可以使用如classpy等工具,方便些我們直接泛讀class文件。也可以試試支持什么class字節(jié)碼級別的單步運行調試工具。哪怕,這個可以一段時間用用jvm匯編編碼工具。
接下來的,理解jvm的垃圾回收機制發(fā)展歷史和各個主流垃圾回收器的工作原理。
這個過程總之太急切。垃圾回收器有各種串行,聯(lián)成一體,新聲代/swap和老年代,以及回收警戒線,endless觸發(fā)條件,各種個樣的基本參數(shù)和不怎么是用超參數(shù),這些G1的H區(qū),ZGC等等。。。還好的是,GC并屬于jvm官方規(guī)范的一部分。
然后把,嘗試著做一些jvm的實踐和實戰(zhàn),
比如,jvm最常見的一種的故障排查和故障總結歸納,性能調優(yōu),熱加載,class字節(jié)碼的動態(tài)操作,asm等。
之后,可以不一段時間實現(xiàn)方法自己的jvm。(其實這個步驟,對很多同學來說不是什么必須了)
這里我推薦推薦幾本書,確實是完全看懂jvm規(guī)范的要求的學習路徑。建議自己基于垃圾回收器。
周老師的《深入理解Java虛擬機》。
下一步是《深入嵌入式java虛擬機》和配套源碼。這個cldc的jvm源碼唯有1M多。目前在oracle的官網上,依然可以可以下載。是一個設計的很不精簡的jvm實現(xiàn)方法。
接下來的,可以不去閱讀《自己動手寫java 虛擬機》。這本書的jvm利用是常規(guī)go語言c語言設計。不過其中也有很多設計并不是太合算。但基本上都不違背了jvm規(guī)范。
這會兒就這個可以去看下github上各種jvm的閉源利用了。有play,scalajvm,javainjava,ajvm,python-jvm,lua,各個版本各個相同的jvm利用。
不過,這些實現(xiàn)都只是基本原理。
后面推薦推薦你自己去看《實戰(zhàn)hotspot》豹子書,了解高級語言虛擬機的圈子。
肯定,垃圾回收的書籍比較好少,這里那就幫我推薦給你垃圾回收的很經典書《The Garbage Collection Cookbook》。實際上對新的垃圾回收算法有興趣,可以不去知乎搜索相關的論文和GC算法開源利用的demo。
5.當然,我的建議只是根據Java本身。
真正的要提升到幾乎能學好java生態(tài),軟件工程,計算機網絡,大數(shù)據基礎知識,mahuot,sparklib,分布式搜索架構,各種消息中間件,緩存中間件,數(shù)據庫,DNS/CDN。。。。。這些大都做互聯(lián)網應用,無法躲閃的。
沒有辦法見意,通用知識比較熟練,專研方向精通滿,去相關生態(tài)所了解。
由于提問是因為java本身。我就并沒有展開攻擊說其他具體方向了。具體解釋的是大的技術方向,并沒有其他答主那樣,具體看去討論語法糖這種級別。希望對提主有不幫助。
有任何問題,歡迎關注知道回答,與我繼續(xù)討論。謝謝啦。
使用java如何打造分布式框架或系統(tǒng),需要哪些知識?
感激邀請。
分布式系統(tǒng)的架構與設計,可能要按實際中項目升級的需要來演繹,要:有SOA的思想,RESTfulAPI得整個明白了,且大量應用;
有都統(tǒng)一登陸賬號,身份認證與合法授權的想法,token的定義與無法激活機制,加解密的處理;
有文件服務器,能提供支持靜態(tài)文件的讀寫服務(包裝成熟可信的API),CDN的概念;
有消息隊列的想法,且適度地應用,比ActiveMQ,Kafka;
有緩存管理的概念,且更多運用,例如Memecache,Redis等;
有web服務器集群,負載均衡的想法,會玩Nginx,HAProxy等;
有數(shù)據庫集群的概念,能玩主從數(shù)據庫復制,讀寫分離等;
有有高級網絡編程的概念,同步異步的應用,多線程的處理,socket程序,非阻塞的IO處理
對https,tcp/ip,telnet有進入到理解與應用;
有對系統(tǒng)的容錯機制如何處理,要做預警處理;
能怎么設計高可用(冷熱備份文件,異地多活等)的系統(tǒng);
有對當下流行的應用設計框架的理解與應用等;
聲明搞分布式系統(tǒng),時間成本與資源成本得先考慮好;
如果不是用戶量下降數(shù)百,點擊率上不去,就放下心來先把系統(tǒng)功能做了才是真;
杰出的系統(tǒng),都是一步步分階段來演繹出來的。
(結束)