项羽java_Java中高级面试题
一.基礎(chǔ)知識(shí):
1)集合類:List和Set比較,各自的子類比較(ArrayList,Vector,LinkedList;HashSet,TreeSet);
2)HashMap的底層實(shí)現(xiàn),之后會(huì)問(wèn)ConcurrentHashMap的底層實(shí)現(xiàn);
3)如何實(shí)現(xiàn)HashMap順序存儲(chǔ):可以參考LinkedHashMap的底層實(shí)現(xiàn);
4)HashTable和ConcurrentHashMap的區(qū)別;
5)String,StringBuffer和StringBuilder的區(qū)別;
6)Object的方法有哪些:比如有wait方法,為什么會(huì)有;
7)wait和sleep的區(qū)別,必須理解;
8)JVM的內(nèi)存結(jié)構(gòu),JVM的算法;
9)強(qiáng)引用,軟引用和弱引用的區(qū)別;
10)數(shù)組在內(nèi)存中如何分配;
11)用過(guò)哪些設(shè)計(jì)模式,手寫(xiě)一個(gè)(除單例);
12)springmvc的核心是什么,請(qǐng)求的流程是怎么處理的,控制反轉(zhuǎn)怎么實(shí)現(xiàn)的;
13)spring里面的aop的原理是什么;
14)mybatis如何處理結(jié)果集:反射,建議看看源碼;
15)java的多態(tài)表現(xiàn)在哪里;
16)接口有什么用;
17)說(shuō)說(shuō)http,https協(xié)議;
18)tcp/ip協(xié)議簇;
19)osi五層網(wǎng)絡(luò)協(xié)議;
20)tcp,udp區(qū)別;
21)用過(guò)哪些加密算法:對(duì)稱加密,非對(duì)稱加密算法;
22)說(shuō)說(shuō)tcp三次握手,四次揮手;
23)cookie和session的區(qū)別,分布式環(huán)境怎么保存用戶狀態(tài);
24)git,svn區(qū)別;
25)請(qǐng)寫(xiě)一段棧溢出、堆溢出的代碼;
26)ThreadLocal可以用來(lái)共享數(shù)據(jù)嗎;
二.IO:
1)bio,nio,aio的區(qū)別;
2)nio框架:dubbo的實(shí)現(xiàn)原理;
3)京東內(nèi)部的jsf是使用的什么協(xié)議通訊:可參見(jiàn)dubbo的協(xié)議;
三.算法:
1)java中常說(shuō)的堆和棧,分別是什么數(shù)據(jù)結(jié)構(gòu);另外,為什么要分為堆和棧來(lái)存儲(chǔ)數(shù)據(jù)。
2)TreeMap如何插入數(shù)據(jù):二叉樹(shù)的左旋,右旋,雙旋;
3)一個(gè)排序之后的數(shù)組,插入數(shù)據(jù),可以使用什么方法?答:二分法;問(wèn):時(shí)間復(fù)雜度是多少?
4)平衡二叉樹(shù)的時(shí)間復(fù)雜度;
5)Hash算法和二叉樹(shù)算法分別什么時(shí)候用;
6)圖的廣度優(yōu)先算法和深度優(yōu)先算法:詳見(jiàn)jvm中垃圾回收實(shí)現(xiàn);
三.多線程相關(guān):
1)說(shuō)說(shuō)阻塞隊(duì)列的實(shí)現(xiàn):可以參考ArrayBlockingQueue的底層實(shí)現(xiàn)(鎖和同步都行);
2)進(jìn)程通訊的方式:消息隊(duì)列,共享內(nèi)存,信號(hào)量,socket通訊等;
3)用過(guò)并發(fā)包的哪些類;
4)什么地方用了多線程;
5)Excutors可以產(chǎn)生哪些線程池;
6)為什么要用線程池;
7)volatile關(guān)鍵字的用法:使多線程中的變量可見(jiàn);
四.數(shù)據(jù)庫(kù)相關(guān)(mysql):
1)msyql優(yōu)化經(jīng)驗(yàn):
2)mysql的語(yǔ)句優(yōu)化,使用什么工具;
3)mysql的索引分類:B+,hash;什么情況用什么索引;
4)mysql的存儲(chǔ)引擎有哪些,區(qū)別是什么;
5)說(shuō)說(shuō)事務(wù)的特性和隔離級(jí)別;
6)悲觀鎖和樂(lè)觀鎖的區(qū)別,怎么實(shí)現(xiàn);
五.mq:
1)mq的原理是什么:有點(diǎn)大。。都可以說(shuō);
2)mq如何保證實(shí)時(shí)性;
3)mq的持久化是怎么做的;
六.nosql相關(guān)(主要是redis):
1)redis和memcache的區(qū)別;
2)用redis做過(guò)什么;
3)redis是如何持久化的:rdb和aof;
4)redis集群如何同步;
5)redis的數(shù)據(jù)添加過(guò)程是怎樣的:哈希槽;
6)redis的淘汰策略有哪些;
7)redis有哪些數(shù)據(jù)結(jié)構(gòu);
七.zookeeper:
1)zookeeper是什么;
2)zookeeper哪里用到;
3)zookeeper的選主過(guò)程;
4)zookeeper集群之間如何通訊;
5)你們的zookeeper的節(jié)點(diǎn)加密是用的什么方式;
6)分布式鎖的實(shí)現(xiàn)過(guò)程;
八.linux相關(guān):
1)linux常用的命令有哪些;
2)如何獲取java進(jìn)程的pid;
3)如何獲取某個(gè)進(jìn)程的網(wǎng)絡(luò)端口號(hào);
4)如何實(shí)時(shí)打印日志;
5)如何統(tǒng)計(jì)某個(gè)字符串行數(shù);
九.設(shè)計(jì)與思想:
1)重構(gòu)過(guò)代碼沒(méi)有?說(shuō)說(shuō)經(jīng)驗(yàn);
2)一千萬(wàn)的用戶實(shí)時(shí)排名如何實(shí)現(xiàn);
3)五萬(wàn)人并發(fā)搶票怎么實(shí)現(xiàn);
總結(jié)
以上是生活随笔為你收集整理的项羽java_Java中高级面试题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: java equals重写原则_java
- 下一篇: java必知必会_Java必知必会--s