1. 程式人生 > 其它 >好友給我分享了一份面試官最愛問的Java面試題,搞懂這些直接來阿里入職

好友給我分享了一份面試官最愛問的Java面試題,搞懂這些直接來阿里入職

好友給我分享了一份面試官最愛問的Java面試題,搞懂這些直接來阿里入職

Linux 專題

微服務專題

  • 微服務架構有哪些優勢?
  • 微服務有哪些特點?
  • 設計微服務的最佳實踐是什麼?
  • 微服務架構如何運作?
  • 微服務架構的優缺點是什麼?
  • 單片,SOA 和微服務架構有什麼區別?
  • 在使用微服務架構時,您面臨哪些挑戰?
  • SOA 和微服務架構之間的主要區別是什麼?
  • 什麼是 REST / RESTful 以及它的用途是什麼?
  • 什麼是不同型別的微服務測試?

Kafka 專題

  • Kafka 是什麼
  • 消費者設計
  • 如何獲取 topic 主題的列表
  • 生產者和消費者的命令列是什麼?
  • 為什麼需要訊息系統,mysql 不能滿足需求嗎?
  • Zookeeper 對於 Kafka 的作用是什麼?
  • Kafka 與傳統 MQ 訊息系統之間有三個關鍵區別
  • 講一講 kafka 的 ack的三種機制
  • kafka 的高可用機制是什麼?
  • kafka 如何不消費重複資料?比如扣款,我們不能重複的扣。
  • kafka 分散式(不是單機)的情況下,如何保證訊息的順序消費?

Elasticsearch 專題

  • Elasticsearch 瞭解多少,說說你們公司 es 的叢集架構,索引資料大小,分片有多少,以及一些調優手段 。
  • Elasticsearch 的倒排索引是什麼
  • Elasticsearch 是如何實現 master 選舉的
  • 詳細描述一下 Elasticsearch 搜尋的過程?
  • Elasticsearch 是如何實現 Master 選舉的?
  • 客戶端在和叢集連線時,如何選擇特定的節點執行請求的?
  • 在併發情況下,Elasticsearch 如果保證讀寫一致?
  • Elasticsearch 對於大資料量(上億量級)的聚合如何實現?
  • 對於 GC 方面,在使用 Elasticsearch 時要注意什麼?
  • 如何監控 Elasticsearch 叢集狀態?

演算法專題

  • 二分查詢
  • 氣泡排序演算法
  • 插入排序演算法
  • 快速排序演算法
  • 希爾排序演算法
  • 歸併排序演算法
  • 桶排序演算法
  • 基數排序演算法
  • 剪枝演算法
  • 回溯演算法
  • 最短路徑演算法
  • 最小生成樹演算法
  • AES
  • RSA
  • CRC
  • MD5

資料結構專題

  • 棧(stack)
  • 佇列(queue)
  • 連結串列(Link)
  • 散列表(Hash Table)
  • 排序二叉樹
  • 字首樹
  • 紅黑樹
  • B-TREE
  • 點陣圖

Zookeeper 專題

  • 什麼是Zookeeper?
  • Zookeeper 如何保證了分散式一致性特性?
  • ZooKeeper 提供了什麼?
  • 瞭解ZAB 協議?
  • zookeeper 是如何保證事務的順序一致性的?
  • zk 節點宕機如何處理?
  • zookeeper 負載均衡和 nginx 負載均衡區別
  • 分散式叢集中為什麼會有 Master?
  • Zookeeper 有哪幾種幾種部署模式?
  • 叢集支援動態新增機器嗎?
  • chubby 是什麼,和 zookeeper 比你怎麼看 ?
  • Zookeeper 的 java 客戶端都有哪些?
  • ZAB 和 Paxos 演算法的聯絡與區別?

MyBatis 專題

Dubbo 專題

  • 服務呼叫是阻塞的嗎?
  • 一般使用什麼註冊中心?還有別的選擇嗎?
  • 服務上線怎麼不影響舊版本?
  • 如何解決服務呼叫鏈過長的問題?
  • Dubbo 叢集容錯有幾種方案?
  • Dubbo 服務降級,失敗重試怎麼做?
  • Dubbo Monitor 實現原理?
  • Dubbo 用到哪些設計模式?
  • Dubbo 支援分散式事務嗎?
  • 說說核心的配置有哪些?
  • Dubbo 推薦用什麼協議?
  • Dubbo SPI 和 Java SPI 區別?
  • 為什麼要用 Dubbo?
  • Dubbo 的整體架構設計有哪些分層?
  • 預設使用的是什麼通訊框架,還有別的選擇嗎?

RabbitMQ 專題

Spring 專題

SpringCloud 專題

SpringBoot 專題

MongoDB 專題

  • mongodb是什麼?
  • mongodb有哪些特點?
  • NoSQL資料庫有哪些型別?
  • MySQL與MongoDB之間最基本的差別是什麼?
  • MongoDB成為最好NoSQL資料庫的原因是什麼?
  • 你怎麼比較MongoDB、CouchDB及CouchBase?
  • 分析器在MongoDB中的作用是什麼?
  • 如何執行事務/加鎖?
  • MongoDB支援儲存過程嗎?如果支援的話,怎麼用?

Memcached 專題

  • Memcached 是什麼,有什麼作用?
  • Memcached 最大的優勢是什麼?
  • Memcached 服務在企業叢集架構中有哪些應用場景?
  • Memcached 服務分散式叢集如何實現?
  • Memcached 服務特點及工作原理是什麼?
  • 簡述 Memcached 記憶體管理機制原理?
  • Memcached 是怎麼工作的?
  • Memcached 如何實現冗餘機制?
  • Memcached 如何處理容錯的?
  • Memcached 的多執行緒是什麼?如何使用它們?
  • 如何實現叢集中的 Session 共享儲存?
  • Memcached 與 Redis 的區別

Redis 專題

  • 什麼是 Redis?
  • 使用 Redis 有哪些好處?
  • Redis 相比 Memcached 有哪些優勢?
  • Redis 是單程序單執行緒的?
  • Redis持久化機制
  • 快取雪崩、快取穿透、快取預熱、快取更新、快取降級等問題
  • Redis的資料型別,以及每種資料型別的使用場景
  • Redis的過期策略以及記憶體淘汰機制
  • Redis 常見效能問題和解決方案?
  • 為什麼Redis的操作是原子性的,怎麼保證原子性的?
  • Redis 的持久化機制是什麼?各自的優缺點?
  • Redis 過期鍵的刪除策略?
  • Redis 的回收策略(淘汰策略)?
  • Redis 的同步機制瞭解麼?
  • 是否使用過 Redis 叢集,叢集的原理是什麼?

MySQL 專題

  • 資料庫引擎有哪些
  • 資料庫的三正規化是什麼
  • 常見索引原則有哪些
  • 什麼是內聯接、左外聯接、右外聯接?
  • 併發事務帶來哪些問題?
  • 事務隔離級別有哪些?MySQL的預設隔離級別是?
  • 大表如何優化?
  • MySQL 中有哪幾種鎖?
  • MySQL 中有哪些不同的表格?
  • 簡述在 MySQL 資料庫中 MyISAM 和 InnoDB 的區別
  • 主鍵和候選鍵有什麼區別?
  • 列對比運算子是什麼?
  • MySQL 支援事務嗎?
  • 索引的底層實現原理和優化

JVM 專題

  • 怎麼獲取 Java 程式使用的記憶體?堆使用的百分比?
  • 你能保證 GC 執行嗎?
  • 解釋 Java 堆空間及 GC?
  • JRE、JDK、JVM 及 JIT 之間有什麼不同?
  • 怎樣通過 Java 程式來判斷 JVM 是 32 位 還是 64位?
  • java中會存在記憶體洩漏嗎,請簡單描述。
  • Java 中堆和棧有什麼區別?
  • 描述一下 JVM 載入 class 檔案的原理機制
  • GC 是什麼?為什麼要有 GC?
  • 講講JVM的新生代、老年代、永久代、
  • JVM雙親委派瞭解過嗎?
  • JVM的永久代中會發生垃圾回收麼
  • 什麼是Java虛擬機器?為什麼Java被稱作是“平臺無關的程式語言”?

Java併發專題

  • 簡述一下你對執行緒池的理解
  • Java中實現多執行緒有幾種方法
  • 如何停止一個正在執行的執行緒
  • volatile關鍵字的作用?可以保證有序性嗎?
  • SynchronizedMap和ConcurrentHashMap有什麼區別?
  • 說一說自己對於 synchronized 關鍵字的瞭解
  • 說說自己是怎麼使用 synchronized 關鍵字,在專案中用到了嗎synchronized關鍵字最主要的三種使用方式
  • 什麼是執行緒安全?Vector是一個執行緒安全類嗎?
  • 講一下樂觀鎖、悲觀鎖、自旋鎖
  • 死鎖與活鎖的區別,死鎖與飢餓的區別?
  • 執行緒與程序的區別?
  • 什麼是多執行緒中的上下文切換?

Java序列化 + 註解 專題

Java IO/NIO + 反射 專題

  • Java IO與 NIO的區別
  • 位元組流與字元流的區別
  • 多路複用
  • 訊號驅動
  • 非同步同步
  • 反射的作用
  • 哪裡會用到反射機制?
  • 反射實現方式
  • Java反射類

Java異常處理專題

Java集合/泛型專題

  • ArrayList和linkedList的區別
  • HashMap和HashTable的區別
  • Array與ArrayList有什麼不一樣?
  • 說說List,Set,Map三者的區別
  • 什麼是Set集合
  • Vector( 陣列實現、 執行緒同步)
  • 說說LinkList(連結串列)
  • HashMap(陣列+連結串列+紅黑樹)
  • HashTable(執行緒安全)
  • 型別萬用字元?
  • 泛型類
  • 什麼是TreeSet(二叉樹)

總結

面試建議是,一定要自信,敢於表達,面試的時候我們對知識的掌握有時候很難面面俱到,把自己的思路說出來,而不是直接告訴面試官自己不懂,這也是可以加分的。

以上就是螞蟻技術四面和HR面試題目,以下最新總結的最全,範圍包含最全MySQL、Spring、Redis、JVM等最全面試題和答案,僅用於參考

如何獲取面試參考資料?戳這裡免費領取