JAVA工程師面試題【來自併發編程網】

基礎題:

  1. Java線程的狀態
  2. 進程和線程的區別,進程間如何通信,線程間如何通信
  3. HashMap的數據結構是什麼?如何實現的。和HashTable,ConcurrentHashMap的區別
  4. Cookie和Session的區別*
  5. 索引有什麼用?如何建索引?
  6. ArrayList是如何實現的,ArrayList和LinedList的區別?ArrayList如何實現擴容*
  7. equals方法實現
  8. 面向對象
  9. 線程狀態,BLOCKED和WAITING有什麼區別
  10. JVM如何加載字節碼文件
  11. JVM GC,GC算法。
  12. 什麼狀況會出現Full GC,什麼狀況會出現yong GC
  13. JVM內存模型
  14. Java運行時數據區
  15. 事務的實現原理

技術深度

  1. 有沒有看過JDK源碼,看過的類實現原理是什麼。
  2. HTTP協議
  3. TCP協議
  4. 一致性Hash算法
  5. JVM如何加載字節碼文件
  6. 類加載器如何卸載字節碼
  7. IO和NIO的區別,NIO優勢
  8. Java線程池的實現原理,keepAliveTime等參數的做用。
  9. HTTP鏈接池實現原理
  10. 數據庫鏈接池實現原理
  11. 數據庫的實現原理

技術框架

  1. 看過哪些開源框架的源碼
  2. 爲何要用Redis,Redis有哪些優缺點?Redis如何實現擴容?
  3. Netty是如何使用線程池的,爲何這麼使用
  4. 爲何要使用Spring,Spring的優缺點有哪些
  5. Spring的IOC容器初始化流程
  6. Spring的IOC容器實現原理,爲何能夠經過byName和ByType找到Bean
  7. Spring AOP實現原理
  8. 消息中間件是如何實現的,技術難點有哪些

技術架構

  1. 如何搭建一個高可用系統
  2. 哪些設計模式能夠增長系統的可擴展性
  3. 介紹設計模式,如模板模式,命令模式,策略模式,適配器模式、橋接模式、裝飾模式,觀察者模式,狀態模式,訪問者模式。
  4. 抽象能力,怎麼提升研發效率。
  5. 什麼是高內聚低耦合,請舉例子如何實現
  6. 什麼狀況用接口,什麼狀況用消息
  7. 若是AB兩個系統互相依賴,如何解除依賴
  8. 如何寫一篇設計文檔,目錄是什麼
  9. 什麼場景應該拆分系統,什麼場景應該合併系統
  10. 系統和模塊的區別,分別在什麼場景下使用

分佈式系統算法

  1. 分佈式事務,兩階段提交。
  2. 如何實現分佈式鎖
  3. 如何實現分佈式Session
  4. 如何保證消息的一致性
  5. 負載均衡
  6. 正向代理(客戶端代理)和反向代理(服務器端代理)
  7. CDN實現原理
  8. 怎麼提高系統的QPS和吞吐量

實戰能力

  1. 有沒有處理過線上問題?出現內存泄露,CPU利用率標高,應用無響應時如何處理的。
  2. 開發中有沒有遇到什麼技術問題?如何解決的
  3. 若是有幾十億的白名單,天天白天須要高併發查詢,晚上須要更新一次,如何設計這個功能。
  4. 新浪微博是如何實現把微博推給訂閱者
  5. Google是如何在一秒內把搜索結果返回給用戶的。
  6. 12306網站的訂票系統如何實現,如何保證不會票不被超賣。
  7. 如何實現一個秒殺系統,保證只有幾位用戶能買到某件商品。

軟能力

  1. 如何學習一項新技術,好比如何學習Java的,重點學習什麼
  2. 有關注哪些新的技術
  3. 工做任務很是多很是雜時如何處理
  4. 項目出現延遲如何處理
  5. 和同事的設計思路不同怎麼處理
  6. 如何保證開發質量
  7. 職業規劃是什麼?短時間,長期目標是什麼
  8. 團隊的規劃是什麼
  9. 能介紹下從工做到如今本身的成長在那裏
相關文章
相關標籤/搜索