一叶圃、數(shù)據(jù)結(jié)構(gòu)與算法基礎(chǔ)
說一下幾種常見的排序算法和分別的復(fù)雜度。
用Java寫一個(gè)冒泡排序算法
描述一下鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)践图。
如何遍歷一棵二叉樹掺冠?
倒排一個(gè)LinkedList。
用Java寫一個(gè)遞歸遍歷目錄下面的所有文件码党。
二德崭、Java基礎(chǔ)
接口與抽象類的區(qū)別?
Java中的異常有哪幾類揖盘?分別怎么使用眉厨?
常用的集合類有哪些?比如List如何排序兽狭?
ArrayList和LinkedList內(nèi)部的實(shí)現(xiàn)大致是怎樣的缺猛?他們之間的區(qū)別和優(yōu)缺點(diǎn)?
內(nèi)存溢出是怎么回事椭符?請(qǐng)舉一個(gè)例子?
==和equals的區(qū)別耻姥?
hashCode方法的作用销钝?
NIO是什么?適用于何種場景琐簇?
HashMap實(shí)現(xiàn)原理蒸健,如何保證HashMap的線程安全?
JVM內(nèi)存結(jié)構(gòu)婉商,為什么需要GC似忧?
NIO模型,select/epoll的區(qū)別丈秩,多路復(fù)用的原理
Java中一個(gè)字符占多少個(gè)字節(jié)盯捌,擴(kuò)展再問int, long, double占多少字節(jié)
創(chuàng)建一個(gè)類的實(shí)例都有哪些辦法?
final/finally/finalize的區(qū)別蘑秽?
Session/Cookie的區(qū)別饺著?
String/StringBuffer/StringBuilder的區(qū)別箫攀,擴(kuò)展再問他們的實(shí)現(xiàn)?
Servlet的生命周期幼衰?
如何用Java分配一段連續(xù)的1G的內(nèi)存空間靴跛?需要注意些什么?
Java有自己的內(nèi)存回收機(jī)制渡嚣,但為什么還存在內(nèi)存泄露的問題呢梢睛?
什么是java序列化,如何實(shí)現(xiàn)java序列化?(寫一個(gè)實(shí)例)识椰?
String s = new String("abc");創(chuàng)建了幾個(gè) String Object?
三绝葡、JVM
JVM堆的基本結(jié)構(gòu)。
JVM的垃圾算法有哪幾種裤唠?CMS垃圾回收的基本流程挤牛?
JVM有哪些常用啟動(dòng)參數(shù)可以調(diào)整,描述幾個(gè)种蘸?
如何查看JVM的內(nèi)存使用情況墓赴?
Java程序是否會(huì)內(nèi)存溢出,內(nèi)存泄露情況發(fā)生航瞭?舉幾個(gè)例子诫硕。
你常用的JVM配置和調(diào)優(yōu)參數(shù)都有哪些?分別什么作用刊侯?
JVM的內(nèi)存結(jié)構(gòu)章办?
常用的GC策略,什么時(shí)候會(huì)觸發(fā)YGC滨彻,什么時(shí)候觸發(fā)FGC藕届?
四、多線程/并發(fā)
如何創(chuàng)建線程亭饵?如何保證線程安全休偶?
如何實(shí)現(xiàn)一個(gè)線程安全的數(shù)據(jù)結(jié)構(gòu)
如何避免死鎖
Volatile關(guān)鍵字的作用?
HashMap在多線程環(huán)境下使用需要注意什么辜羊?為什么踏兜?
Java程序中啟動(dòng)一個(gè)線程是用run()還是start()?
什么是守護(hù)線程八秃?有什么用碱妆?
什么是死鎖?如何避免
線程和進(jìn)程的差別是什么昔驱?
Java里面的Threadlocal是怎樣實(shí)現(xiàn)的疹尾?
ConcurrentHashMap的實(shí)現(xiàn)原理是?
sleep和wait區(qū)別
notify和notifyAll區(qū)別
volatile關(guān)鍵字的作
ThreadLocal的作用與實(shí)現(xiàn)
兩個(gè)線程如何串行執(zhí)行
上下文切換是什么含義
可以運(yùn)行時(shí)kill掉一個(gè)線程嗎?
什么是條件鎖航棱、讀寫鎖睡雇、自旋鎖、可重入鎖饮醇?
線程池ThreadPoolExecutor的實(shí)現(xiàn)原理它抱?
五、Linux使用與問題分析排查
使用兩種命令創(chuàng)建一個(gè)文件朴艰?
硬鏈接和軟鏈接的區(qū)別观蓄?
Linux常用命令有哪些?
怎么看一個(gè)Java線程的資源耗用祠墅?
Load過高的可能性有哪些侮穿?
/etc/hosts文件什么做用?
如何快速的將一個(gè)文本中所有“abc”替換為“xyz”毁嗦?
如何在log文件中搜索找出error的日志亲茅?
發(fā)現(xiàn)磁盤空間不夠,如何快速找出占用空間最大的文件狗准?
Java服務(wù)端問題排查(OOM克锣,CPU高,Load高腔长,類沖突)
Java常用問題排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)
Thread dump文件如何分析(Runnable袭祟,鎖,代碼棧捞附,操作系統(tǒng)線程ID關(guān)聯(lián))
如何查看Java應(yīng)用的線程信息巾乳?
六、框架使用
描述一下Hibernate的三個(gè)狀態(tài)鸟召?
Spring中Bean的生命周期胆绊。
SpringMVC或Struts處理請(qǐng)求的流程。
Spring AOP解決了什么問題欧募?怎么實(shí)現(xiàn)的压状?
Spring事務(wù)的傳播屬性是怎么回事?它會(huì)影響什么槽片?
Spring中BeanFactory和FactoryBean有什么區(qū)別?
Spring框架中IOC的原理是什么肢础?
spring的依賴注入有哪幾種方式
struts工作流程
用Spring如何實(shí)現(xiàn)一個(gè)切面还栓?
Spring 如何實(shí)現(xiàn)數(shù)據(jù)庫事務(wù)?
Hibernate對(duì)一二級(jí)緩存的使用传轰,Lazy-Load的理解剩盒;
mybatis如何實(shí)現(xiàn)批量提交?
七慨蛙、數(shù)據(jù)庫相關(guān)
MySQL InnoDB辽聊、Mysaim的特點(diǎn)纪挎?
樂觀鎖和悲觀鎖的區(qū)別?
數(shù)據(jù)庫隔離級(jí)別是什么跟匆?有什么作用异袄?
MySQL主備同步的基本原理。
select * from table t where size > 10 group by size order by size的sql語句執(zhí)行順序玛臂?
如何優(yōu)化數(shù)據(jù)庫性能(索引烤蜕、分庫分表、批量操作迹冤、分頁算法讽营、升級(jí)硬盤SSD、業(yè)務(wù)優(yōu)化泡徙、主從部署)
SQL什么情況下不會(huì)使用索引(不包含橱鹏,不等于,函數(shù))
一般在什么字段上建索引(過濾數(shù)據(jù)最多的字段)
如何從一張表中查出name字段不包含“XYZ”的所有行堪藐?
MySQL莉兰,B+索引實(shí)現(xiàn),行鎖實(shí)現(xiàn)庶橱,SQL優(yōu)化
Redis贮勃,RDB和AOF,如何做高可用苏章、集群
如何解決高并發(fā)減庫存問題
mysql存儲(chǔ)引擎中索引的實(shí)現(xiàn)機(jī)制寂嘉;
數(shù)據(jù)庫事務(wù)的幾種粒度;
行鎖枫绅,表鎖泉孩;樂觀鎖,悲觀鎖
八并淋、網(wǎng)絡(luò)協(xié)議和網(wǎng)絡(luò)編程
TCP建立連接的過程寓搬。
TCP斷開連接的過程。
瀏覽器發(fā)生302跳轉(zhuǎn)背后的邏輯县耽?
HTTP協(xié)議的交互流程句喷。HTTP和HTTPS的差異,SSL的交互流程兔毙?
Rest和Http什么關(guān)系唾琼? 大家都說Rest很輕量,你對(duì)Rest風(fēng)格如何理解澎剥?
TCP的滑動(dòng)窗口協(xié)議有什么用锡溯?講講原理。
HTTP協(xié)議都有哪些方法?
交換機(jī)和路由器的區(qū)別祭饭?
Socket交互的基本流程芜茵?
http協(xié)議(報(bào)文結(jié)構(gòu),斷點(diǎn)續(xù)傳倡蝙,多線程下載九串,什么是長連接)
tcp協(xié)議(建連過程,慢啟動(dòng)悠咱,滑動(dòng)窗口蒸辆,七層模型)
webservice協(xié)議(wsdl/soap格式,與rest協(xié)議的區(qū)別)
NIO的好處析既,Netty線程模型躬贡,什么是零拷貝
九、Redis等緩存系統(tǒng)/中間件/NoSQL/一致性Hash等
列舉一個(gè)常用的Redis客戶端的并發(fā)模型眼坏。
HBase如何實(shí)現(xiàn)模糊查詢拂玻?
列舉一個(gè)常用的消息中間件,如果消息要保序如何實(shí)現(xiàn)宰译?
如何實(shí)現(xiàn)一個(gè)Hashtable檐蚜?你的設(shè)計(jì)如何考慮Hash沖突?如何優(yōu)化沿侈?
分布式緩存闯第,一致性hash
LRU算法,slab分配缀拭,如何減少內(nèi)存碎片
如何解決緩存單機(jī)熱點(diǎn)問題
什么是布隆過濾器咳短,其實(shí)現(xiàn)原理是? False positive指的是蛛淋?
memcache與redis的區(qū)別
zookeeper有什么功能咙好,選舉算法如何進(jìn)行
map/reduce過程,如何用map/reduce實(shí)現(xiàn)兩個(gè)數(shù)據(jù)源的聯(lián)合統(tǒng)計(jì)
十褐荷、設(shè)計(jì)模式與重構(gòu)
你能舉例幾個(gè)常見的設(shè)計(jì)模式
你在設(shè)計(jì)一個(gè)工廠的包的時(shí)候會(huì)遵循哪些原則勾效?
你能列舉一個(gè)使用了Visitor/Decorator模式的開源項(xiàng)目/庫嗎?
你在編碼時(shí)最常用的設(shè)計(jì)模式有哪些叛甫?在什么場景下用层宫?
如何實(shí)現(xiàn)一個(gè)單例?
代理模式(動(dòng)態(tài)代理)
單例模式(懶漢模式其监,并發(fā)初始化如何解決萌腿,volatile與lock的使用)
JDK源碼里面都有些什么讓你印象深刻的設(shè)計(jì)模式使用,舉例看看棠赛?
愿還在路上的程序員哮奇,加油