一访锻、數(shù)據(jù)結(jié)構(gòu)與算法基礎(chǔ)
說一下幾種常見的排序算法和分別的復(fù)雜度褪尝。
用Java寫一個冒泡排序算法
描述一下鏈?zhǔn)酱鎯Y(jié)構(gòu)。
如何遍歷一棵二叉樹期犬?
倒排一個LinkedList河哑。
用Java寫一個遞歸遍歷目錄下面的所有文件。
二龟虎、Java基礎(chǔ)
接口與抽象類的區(qū)別璃谨?
Java中的異常有哪幾類?分別怎么使用?
常用的集合類有哪些佳吞?比如List如何排序拱雏?
ArrayList和LinkedList內(nèi)部的實現(xiàn)大致是怎樣的?他們之間的區(qū)別和優(yōu)缺點容达?
內(nèi)存溢出是怎么回事古涧?請舉一個例子垂券?
==和equals的區(qū)別花盐?
hashCode方法的作用?
NIO是什么菇爪?適用于何種場景算芯?
HashMap實現(xiàn)原理,如何保證HashMap的線程安全凳宙?
JVM內(nèi)存結(jié)構(gòu)熙揍,為什么需要GC?
NIO模型氏涩,select/epoll的區(qū)別届囚,多路復(fù)用的原理
Java中一個字符占多少個字節(jié),擴展再問int, long, double占多少字節(jié)
創(chuàng)建一個類的實例都有哪些辦法是尖?
final/finally/finalize的區(qū)別意系?
Session/Cookie的區(qū)別?
String/StringBuffer/StringBuilder的區(qū)別饺汹,擴展再問他們的實現(xiàn)蛔添?
Servlet的生命周期?
如何用Java分配一段連續(xù)的1G的內(nèi)存空間兜辞?需要注意些什么迎瞧?
Java有自己的內(nèi)存回收機制,但為什么還存在內(nèi)存泄露的問題呢逸吵?
什么是java序列化凶硅,如何實現(xiàn)java序列化?(寫一個實例)?
String s = new String("abc");創(chuàng)建了幾個 String Object?
三扫皱、JVM
JVM堆的基本結(jié)構(gòu)足绅。
JVM的垃圾算法有哪幾種?CMS垃圾回收的基本流程啸罢?
JVM有哪些常用啟動參數(shù)可以調(diào)整编检,描述幾個?
如何查看JVM的內(nèi)存使用情況扰才?
Java程序是否會內(nèi)存溢出允懂,內(nèi)存泄露情況發(fā)生?舉幾個例子衩匣。
你常用的JVM配置和調(diào)優(yōu)參數(shù)都有哪些蕾总?分別什么作用粥航?
JVM的內(nèi)存結(jié)構(gòu)?
常用的GC策略生百,什么時候會觸發(fā)YGC递雀,什么時候觸發(fā)FGC?
四蚀浆、多線程/并發(fā)
如何創(chuàng)建線程缀程?如何保證線程安全?
如何實現(xiàn)一個線程安全的數(shù)據(jù)結(jié)構(gòu)
如何避免死鎖
Volatile關(guān)鍵字的作用市俊?
HashMap在多線程環(huán)境下使用需要注意什么杨凑?為什么?
Java程序中啟動一個線程是用run()還是start()摆昧?
什么是守護線程撩满?有什么用?
什么是死鎖绅你?如何避免
線程和進程的差別是什么伺帘?
Java里面的Threadlocal是怎樣實現(xiàn)的?
ConcurrentHashMap的實現(xiàn)原理是忌锯?
sleep和wait區(qū)別
notify和notifyAll區(qū)別
volatile關(guān)鍵字的作
ThreadLocal的作用與實現(xiàn)
兩個線程如何串行執(zhí)行
上下文切換是什么含義
可以運行時kill掉一個線程嗎伪嫁?
什么是條件鎖、讀寫鎖汉规、自旋鎖礼殊、可重入鎖?
線程池ThreadPoolExecutor的實現(xiàn)原理针史?
五晶伦、Linux使用與問題分析排查
使用兩種命令創(chuàng)建一個文件?
硬鏈接和軟鏈接的區(qū)別啄枕?
Linux常用命令有哪些婚陪?
怎么看一個Java線程的資源耗用?
Load過高的可能性有哪些频祝?
/etc/hosts文件什么做用泌参?
如何快速的將一個文本中所有“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的三個狀態(tài)哮内?
Spring中Bean的生命周期。
SpringMVC或Struts處理請求的流程壮韭。
Spring AOP解決了什么問題北发?怎么實現(xiàn)的?
Spring事務(wù)的傳播屬性是怎么回事泰涂?它會影響什么鲫竞?
Spring中BeanFactory和FactoryBean有什么區(qū)別?
Spring框架中IOC的原理是什么逼蒙?
spring的依賴注入有哪幾種方式
struts工作流程
用Spring如何實現(xiàn)一個切面?
Spring 如何實現(xiàn)數(shù)據(jù)庫事務(wù)寄疏?
Hibernate對一二級緩存的使用是牢,Lazy-Load的理解;
mybatis如何實現(xiàn)批量提交陕截?
七驳棱、數(shù)據(jù)庫相關(guān)
MySQL InnoDB、Mysaim的特點农曲?
樂觀鎖和悲觀鎖的區(qū)別社搅?
數(shù)據(jù)庫隔離級別是什么?有什么作用乳规?
MySQL主備同步的基本原理形葬。
select * from table t where size > 10 group by size order by size的sql語句執(zhí)行順序?
如何優(yōu)化數(shù)據(jù)庫性能(索引暮的、分庫分表笙以、批量操作、分頁算法冻辩、升級硬盤SSD猖腕、業(yè)務(wù)優(yōu)化、主從部署)
SQL什么情況下不會使用索引(不包含恨闪,不等于倘感,函數(shù))
一般在什么字段上建索引(過濾數(shù)據(jù)最多的字段)
如何從一張表中查出name字段不包含“XYZ”的所有行?
MySQL咙咽,B+索引實現(xiàn)老玛,行鎖實現(xiàn),SQL優(yōu)化
Redis,RDB和AOF逻炊,如何做高可用互亮、集群
如何解決高并發(fā)減庫存問題
mysql存儲引擎中索引的實現(xiàn)機制;
數(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很輕量伸刃,你對Rest風(fēng)格如何理解谎砾?
TCP的滑動窗口協(xié)議有什么用?講講原理捧颅。
HTTP協(xié)議都有哪些方法景图?
交換機和路由器的區(qū)別?
Socket交互的基本流程碉哑?
http協(xié)議(報文結(jié)構(gòu)挚币,斷點續(xù)傳,多線程下載扣典,什么是長連接)
tcp協(xié)議(建連過程妆毕,慢啟動,滑動窗口激捏,七層模型)
webservice協(xié)議(wsdl/soap格式设塔,與rest協(xié)議的區(qū)別)
NIO的好處,Netty線程模型远舅,什么是零拷貝
九闰蛔、Redis等緩存系統(tǒng)/中間件/NoSQL/一致性Hash等
列舉一個常用的Redis客戶端的并發(fā)模型。
HBase如何實現(xiàn)模糊查詢图柏?
列舉一個常用的消息中間件序六,如果消息要保序如何實現(xiàn)?
如何實現(xiàn)一個Hashtable蚤吹?你的設(shè)計如何考慮Hash沖突例诀?如何優(yōu)化随抠?
分布式緩存,一致性hash
LRU算法繁涂,slab分配拱她,如何減少內(nèi)存碎片
如何解決緩存單機熱點問題
什么是布隆過濾器,其實現(xiàn)原理是扔罪? False positive指的是秉沼?
memcache與redis的區(qū)別
zookeeper有什么功能,選舉算法如何進行
map/reduce過程矿酵,如何用map/reduce實現(xiàn)兩個數(shù)據(jù)源的聯(lián)合統(tǒng)計
十唬复、設(shè)計模式與重構(gòu)
你能舉例幾個常見的設(shè)計模式
你在設(shè)計一個工廠的包的時候會遵循哪些原則?
你能列舉一個使用了Visitor/Decorator模式的開源項目/庫嗎全肮?
你在編碼時最常用的設(shè)計模式有哪些敞咧?在什么場景下用?
如何實現(xiàn)一個單例辜腺?
代理模式(動態(tài)代理)
單例模式(懶漢模式休建,并發(fā)初始化如何解決,volatile與lock的使用)
JDK源碼里面都有些什么讓你印象深刻的設(shè)計模式使用哪自,舉例看看丰包?
本套試題沒有答案,僅提供給大家參考壤巷。
最后分享一套Java面試寶典《Java核心知識點整理.pdf》“,覆蓋了JVM瞧毙、鎖胧华、高并發(fā)、反射宙彪、Spring原理矩动、微服務(wù)、Zookeeper释漆、數(shù)據(jù)庫悲没、數(shù)據(jù)結(jié)構(gòu)等等”,還有Java208道面試題(含答案)轉(zhuǎn)發(fā)+關(guān)注男图,然后加入群(Java架構(gòu)進階交流群)點擊鏈接加入群聊【Java高級架構(gòu)進階】:https://jq.qq.com/?_wv=1027&k=5GQXY1t 即可免費獲取到示姿!