JAVA工程師面試題【來自併發編程網】
基礎題:
- Java線程的狀態
- 進程和線程的區別,進程間如何通信,線程間如何通信
- HashMap的數據結構是什麼?如何實現的。和HashTable,ConcurrentHashMap的區別
- Cookie和Session的區別*
- 索引有什麼用?如何建索引?
- ArrayList是如何實現的,ArrayList和LinedList的區別?ArrayList如何實現擴容*
- equals方法實現
- 面向對象
- 線程狀態,BLOCKED和WAITING有什麼區別
- JVM如何加載字節碼文件
- JVM GC,GC算法。
- 什麼狀況會出現Full GC,什麼狀況會出現yong GC
- JVM內存模型
- Java運行時數據區
- 事務的實現原理
技術深度
- 有沒有看過JDK源碼,看過的類實現原理是什麼。
- HTTP協議
- TCP協議
- 一致性Hash算法
- JVM如何加載字節碼文件
- 類加載器如何卸載字節碼
- IO和NIO的區別,NIO優勢
- Java線程池的實現原理,keepAliveTime等參數的做用。
- HTTP鏈接池實現原理
- 數據庫鏈接池實現原理
- 數據庫的實現原理
技術框架
- 看過哪些開源框架的源碼
- 爲何要用Redis,Redis有哪些優缺點?Redis如何實現擴容?
- Netty是如何使用線程池的,爲何這麼使用
- 爲何要使用Spring,Spring的優缺點有哪些
- Spring的IOC容器初始化流程
- Spring的IOC容器實現原理,爲何能夠經過byName和ByType找到Bean
- Spring AOP實現原理
- 消息中間件是如何實現的,技術難點有哪些
技術架構
- 如何搭建一個高可用系統
- 哪些設計模式能夠增長系統的可擴展性
- 介紹設計模式,如模板模式,命令模式,策略模式,適配器模式、橋接模式、裝飾模式,觀察者模式,狀態模式,訪問者模式。
- 抽象能力,怎麼提升研發效率。
- 什麼是高內聚低耦合,請舉例子如何實現
- 什麼狀況用接口,什麼狀況用消息
- 若是AB兩個系統互相依賴,如何解除依賴
- 如何寫一篇設計文檔,目錄是什麼
- 什麼場景應該拆分系統,什麼場景應該合併系統
- 系統和模塊的區別,分別在什麼場景下使用
分佈式系統算法
- 分佈式事務,兩階段提交。
- 如何實現分佈式鎖
- 如何實現分佈式Session
- 如何保證消息的一致性
- 負載均衡
- 正向代理(客戶端代理)和反向代理(服務器端代理)
- CDN實現原理
- 怎麼提高系統的QPS和吞吐量
實戰能力
- 有沒有處理過線上問題?出現內存泄露,CPU利用率標高,應用無響應時如何處理的。
- 開發中有沒有遇到什麼技術問題?如何解決的
- 若是有幾十億的白名單,天天白天須要高併發查詢,晚上須要更新一次,如何設計這個功能。
- 新浪微博是如何實現把微博推給訂閱者
- Google是如何在一秒內把搜索結果返回給用戶的。
- 12306網站的訂票系統如何實現,如何保證不會票不被超賣。
- 如何實現一個秒殺系統,保證只有幾位用戶能買到某件商品。
軟能力
- 如何學習一項新技術,好比如何學習Java的,重點學習什麼
- 有關注哪些新的技術
- 工做任務很是多很是雜時如何處理
- 項目出現延遲如何處理
- 和同事的設計思路不同怎麼處理
- 如何保證開發質量
- 職業規劃是什麼?短時間,長期目標是什麼
- 團隊的規劃是什麼
- 能介紹下從工做到如今本身的成長在那裏
歡迎關注本站公眾號,獲取更多信息