首先說結論:來得及!
分享一下自學的歷程,目前題主這個階段建議多練一點算法方面的東西。
進行階段五:算法數據結構深入的訓練學習。
階段一:視頻學習主要是看黑馬和尚硅谷的培訓視頻(百度搜索,官網上就可以找到)??匆曨l學習的最大好處就是入門很快,看一遍,再跟著敲一遍,但是缺點就是時間會花費長一些。我入門階段基本上都是看視頻學習,建議是找最新的視頻學習,因為培訓機構也會根據公司每年面試的側重點調整自己的教學方案。
階段二:書籍學習視頻學習一般都是比較基礎和偏向案例實現的的教學,如果要想系統的了解某一模塊的知識,閱讀專業書籍是少不了的。如果有時間肯定多讀一些書好,但是最優的做法是在有限的時間內閱讀完經典書籍。拿 Java 后端來說,《Java編程思想》、《深入理解Java虛擬機》,毫不夸張的說幾乎每次面試都會有很多知識點都是出自這些書中。所以,這類書籍,多讀幾遍。最好看完后,能夠寫出自己的讀書筆記。我一般是寫讀書筆記前,會看一看別人的讀書筆記,看看自己對書中的知識點是否有理解偏差或者有遺漏的地方。
階段三:博客學習這一階段是一個持續的過程,主要是寫博客和看博客。總感覺看了書很快就忘了,所以為了以后高效的復習,開始寫了一些博客,當然博客內容主要來源自書本以及一些大牛的博客,再加上自己的理解。
階段四:實驗室項目一共做過兩個校企合作項目,這兩個項目雖然很簡單,都是單點的 web 服務,但是卻給自學 Java 帶來了很大的幫助。 而且在最開始找實習的時候,這兩段項目還是起了很大的作用。個人感覺項目簡單也沒有關系,只要你把項目中涉及到的知識點都搞清楚,還是很加分的。至少把自己做的東西弄懂了。
階段五:算法數據結構深入1. 數據結構與算法:《劍指Offer》、LeetCode Top100、常考的一些算法:TopK、生產者消費者模式、多線程交替打印、HashMap 的簡單實現等等;
2. 計算機網絡:五層/七層協議、TCP 和 UDP 的區別、TCP 三次握手和四次揮手、HTTP 的特點、HTTP 與 HTTPS 的區別、HTTPS 過程等等;
3. 計算機操作系統:進程與線程的區別、死鎖的概念/檢測/避免、進程間的通信方式、內存管理等等;
4. 設計模式:單例模式、工廠三兄弟、適配器模式、代理模式、裝飾者模式等等,以及項目中和 JDK/Spring中用到過的設計模式;
5. Java 語言基礎:重載和重寫的區別、抽象類和接口的區別、String/StringBuilder/StringBuffer 的區別、關鍵字(static、super、this、transient)、異常、IO 流、反射、動態代理、序列化等等;
6. Java 集合類:HashMap 的 get、put、resize、JDK1.7 和 1.8、多線程下會發生什么問題、HashMap 和 HashTable/ConcurrentHashMap 的區別、ArrayList 和 LinkedList 的區別等等;
7. Java 并發編程:線程的狀態轉換、wait 和 sleep 的區別、synchronized 關鍵字、volatile 關鍵字、鎖:ReentranrLock、讀寫鎖等、線程池:核心參數、類型等等;
8. Java 虛擬機:運行時數據區、垃圾回收算法、垃圾回收器、垃圾回收策略、JVM 監控和調優、類加載機制、Java 內存模型等等;
9. MySQL:常用的 SQL 語句、索引的數據結構、類型及其優化、事務、鎖、存儲引擎、主從復制、分庫分表等等;
10. Spring:AOP:代理方式、JDK 動態代理的實現;IOC:Bean 的生命周期和作用域、單例 Bean 的線程安全問題;事務:隔離級別、傳播特性等等;
11. SpringMVC:核心組件、處理請求的流程等等;
12. MyBatis:分頁方式、延遲加載、一級和二級緩存等等;
13. Linux:需要掌握基本的操作指令;
14. Redis:基本的數據類型、使用場景、緩存穿透、緩存雪崩、持久化、緩存和數據庫雙寫一致性問題等等;
15. 消息隊列:使用場景、如何保證消息不被重復消費、如何保證可靠傳輸、如何保證順序性等等;
16. Zookeeper:主要功能、部署模式、狀態同步、通知機制等等;
17. 分布式:分布式框架 Dubbo :基本組件、協議、集群容錯模式、負載均衡策略等等;分布式事務及其解決方案、分布式鎖及其解決方案。
有幫助,請點個贊鼓勵一下