java 需要準備的知識(轉摘)
阿新 • • 發佈:2018-04-27
排序算法 asp redis持久化 數據結構和算法 emca 怎樣 配置 GC sync
需要準備的知識
以下為在近期面試中比較有印象的問題,也就不分公司了,因為沒什麽意義,大致分類記錄一下,目前只想起這麽多,不過一定要知道這些問題只是冰山一角,就算都會了也不能怎麽樣,最最重要的,還是堅實的基礎,清醒的頭腦。
Java基礎
- HashMap的源碼,實現原理,JDK8中對HashMap做了怎樣的優化。
- HaspMap擴容是怎樣擴容的,為什麽都是2的N次冪的大小。
- HashMap,HashTable,ConcurrentHashMap的區別。
- 極高並發下HashTable和ConcurrentHashMap哪個性能更好,為什麽,如何實現的。
- HashMap在高並發下如果沒有處理線程安全會有怎樣的安全隱患,具體表現是什麽。
- java中四種修飾符的限制範圍。
- Object類中的方法。
- 接口和抽象類的區別,註意JDK8的接口可以有實現。
- 動態代理的兩種方式,以及區別。
- Java序列化的方式。
- 傳值和傳引用的區別,Java是怎麽樣的,有沒有傳值引用。
- 一個ArrayList在循環過程中刪除,會不會出問題,為什麽。
- @transactional註解在什麽情況下會失效,為什麽。
數據結構和算法
- B+樹
- 快速排序,堆排序,插入排序(其實八大排序算法都應該了解
- 一致性Hash算法,一致性Hash算法的應用
JVM
- JVM的內存結構。
- JVM方法棧的工作過程,方法棧和本地方法棧有什麽區別。
- JVM的棧中引用如何和堆中的對象產生關聯。
- 可以了解一下逃逸分析技術。
- GC的常見算法,CMS以及G1的垃圾回收過程,CMS的各個階段哪兩個是Stop the world的,CMS會不會產生碎片,G1的優勢。
- 標記清除和標記整理算法的理解以及優缺點。
- eden survivor區的比例,為什麽是這個比例,eden survivor的工作過程。
- JVM如何判斷一個對象是否該被GC,可以視為root的都有哪幾種類型。
- 強軟弱虛引用的區別以及GC對他們執行怎樣的操作。
- Java是否可以GC直接內存。
- Java類加載的過程。
- 雙親委派模型的過程以及優勢。
- 常用的JVM調優參數。
- dump文件的分析。
- Java有沒有主動觸發GC的方式(沒有)。
多線程
- Java實現多線程有哪幾種方式。
- Callable和Future的了解。
- 線程池的參數有哪些,在線程池創建一個線程的過程。
- volitile關鍵字的作用,原理。
- synchronized關鍵字的用法,優缺點。
- Lock接口有哪些實現類,使用場景是什麽。
- 可重入鎖的用處及實現原理,寫時復制的過程,讀寫鎖,分段鎖(ConcurrentHashMap中的segment)。
- 悲觀鎖,樂觀鎖,優缺點,CAS有什麽缺陷,該如何解決。
- ABC三個線程如何保證順序執行。
- 線程的狀態都有哪些。
- sleep和wait的區別。
- notify和notifyall的區別。
- ThreadLocal的了解,實現原理。
數據庫相關
- 常見的數據庫優化手段
- 索引的優缺點,什麽字段上建立索引
- 數據庫連接池。
- durid的常用配置。
計算機網絡
- TCP,UDP區別。
- 三次握手,四次揮手,為什麽要四次揮手。
- 長連接和短連接。
- 連接池適合長連接還是短連接。
設計模式
- 觀察者模式
- 代理模式
- 單例模式,有五種寫法,可以參考文章單例模式的五種實現方式
- 可以考Spring中使用了哪些設計模式
分布式相關
- 分布式事務的控制。
- 分布式鎖如何設計。
- 分布式session如何設計。
- dubbo的組件有哪些,各有什麽作用。
- zookeeper的負載均衡算法有哪些。
- dubbo是如何利用接口就可以通信的。
緩存相關
- redis和memcached的區別。
- redis支持哪些數據結構。
- redis是單線程的麽,所有的工作都是單線程麽。
- redis如何存儲一個String的。
- redis的部署方式,主從,集群。
- redis的哨兵模式,一個key值如何在redis集群中找到存儲在哪裏。
- redis持久化策略。
框架相關
- SpringMVC的Controller是如何將參數和前端傳來的數據一一對應的。
- Mybatis如何找到指定的Mapper的,如何完成查詢的。
- Quartz是如何完成定時任務的。
- 自定義註解的實現。
- Spring使用了哪些設計模式。
- Spring的IOC有什麽優勢。
- Spring如何維護它擁有的bean。
一些較新的東西
- JDK8的新特性,流的概念及優勢,為什麽有這種優勢。
- 區塊鏈了解
- 如何設計雙11交易總額面板,要做到高並發高可用。
一些小建議
- 可以去leetcode上刷題換換思路。
- 八大排序算法一定要手敲一遍(快排,堆排尤其重要)。
- 了解一些新興的技術。
- 面試之後面試官都會問你有沒有什麽問題,千萬不要沒問題,也別傻乎乎的問一些敏感問題。
- 了解你要面試的公司的產品及競爭產品。
幾個鏈接
- 很多Java面試題
- 更多Java面試題
- 還是Java面試題
java 需要準備的知識(轉摘)