Java集合19題
這個算是java中的基礎題吧,但是不要小看這些題,有一些可能都回答不上來,我發現最近關于底層問題問的越來越多了,這也算一個基本線吧,如果回答不上來就涼涼了,
- ArrayList 和 Vector 的區別,
- 說說 ArrayList,Vector, LinkedList 的存盤性能和特性,
- 快速失敗 (fail-fast) 和安全失敗 (fail-safe) 的區別是什么?
- hashmap 的資料結構,
- HashMap 的作業原理是什么?
- Hashmap 什么時候進行擴容呢?
- List、Map、Set 三個介面,存取元素時,各有什么特點?
- Set 里的元素是不能重復的,那么用什么方法來區分重復與否呢? 是用 == 還是 equals()? 它們有何區別?
- 兩個物件值相同 (x.equals(y) == true),但卻可有不同的 hash code,這句話對不對?
- heap 和 stack 有什么區別,
- Java 集合類框架的基本介面有哪些?
- HashSet 和 TreeSet 有什么區別?
- HashSet 的底層實作是什么?
- LinkedHashMap 的實作原理?
- 為什么集合類沒有實作 Cloneable 和 Serializable 介面?
- 什么是迭代器 (Iterator)?
- Iterator 和 ListIterator 的區別是什么?
- 陣列 (Array) 和串列 (ArrayList) 有什么區別?什么時候應該使用 Array 而不是 ArrayList?
- Java 集合類框架的最佳實踐有哪些?
JVM與調優18題
JVM算是去大廠必會的一個知識點了,性能調優問題、垃圾回識訓制、雙親委派以及體系結構,這些會的越多加分就越多,

- Java 類加載程序?
- 描述一下 JVM 加載 Class 檔案的原理機制?
- Java 記憶體分配,
- GC 是什么? 為什么要有 GC?
- 簡述 Java 垃圾回識訓制
- 如何判斷一個物件是否存活?(或者 GC 物件的判定方法)
- 垃圾回收的優點和原理,并考慮 2 種回識訓制
- 垃圾回收器的基本原理是什么?垃圾回收器可以馬上回收記憶體嗎?有什么辦法主動通知虛擬機進行垃圾回收?
- Java 中會存在記憶體泄漏嗎,請簡單描述
- 深拷貝和淺拷貝,
- System.gc() 和 Runtime.gc() 會做什么事情?
- finalize() 方法什么時候被呼叫?解構式 (finalization) 的目的是什么?
- 如果物件的參考被置為 null,垃圾收集器是否會立即釋放物件占用的記憶體?
- 串行(serial)收集器和吞吐量(throughput)收集器的區別是什么?
- 在 Java 中,物件什么時候可以被垃圾回收?
- 簡述 Java 記憶體分配與回收策略以及 Minor GC 和 Major GC,
- VM 的永久代中會發生垃圾回收么?
并發編程24題
并發是重點的重點,記得有一次面試關于并發問題面試官死磕了我半個小時,從鎖機制到執行緒池被安排的明明白白的,

- Synchronized 用過嗎,其原理是什么?
- 你剛才提到獲取物件的鎖,這個“鎖”到底是什么?如何確定物件的鎖?
- 什么是可重入性,為什么說 Synchronized 是可重入鎖?
- VM 對 Java 的原生鎖做了哪些優化?48
- 為什么說 Synchronized 是非公平鎖?49
- 什么是鎖消除和鎖粗化?49
- 為什么說 Synchronized 是一個悲觀鎖?樂觀鎖的實作原理又是什么?什么是 CAS,它有什么特性?
- 樂觀鎖一定就是好的嗎?
- 跟 Synchronized 相比,可重入鎖 ReentrantLock 其實作原理有什么不同?
- 那么請談談 AQS 框架是怎么回事兒?
- 請盡可能詳盡地對比下 Synchronized 和 ReentrantLock 的異同,
- ReentrantLock 是如何實作可重入性的?
- 除了 ReetrantLock,你還接觸過 JUC 中的哪些并發工具?
- 請談談 ReadWriteLock 和 StampedLock,
- 如何讓 Java 的執行緒彼此同步?你了解過哪些同步器?請分別介紹下,
- CyclicBarrier 和 CountDownLatch 看起來很相似,請對比下呢?
- Java 執行緒池相關問題
- Java 中的執行緒池是如何實作的?
- 創建執行緒池的幾個核心構造引數?
- 執行緒池中的執行緒是怎么創建的?是一開始就隨著執行緒池的啟動創建好的嗎?
- 既然提到可以通過配置不同引數創建出不同的執行緒池,那么 Java 中默認實作好的執行緒池又有哪些呢?請比較它們的異同
- 如何在 Java 執行緒池中提交執行緒?
- 什么是 Java 的記憶體模型,Java 中各個執行緒是怎么彼此看到對方的變數的?
- 請談談 volatile 有什么特點,為什么它能保證變數對所有執行緒的可見性?
spring 22題
我相信大家都用過Spring吧,身為開源框架他的重要性毋庸置疑,IOC、AOP兩大必問核心,從注解到標簽都有可能問到,

- 1、什么是 Spring 框架?Spring 框架有哪些主要模塊?
- 2、使用 Spring 框架能帶來哪些好處?
- 3、什么是控制反轉(IOC)?什么是依賴注入?
- 4、請解釋下 Spring 框架中的 IoC?
- 5、BeanFactory 和 ApplicationContext 有什么區別?
- 6、Spring 有幾種配置方式?
- 7、如何用基于 XML 配置的方式配置 Spring?
- 8、如何用基于 Java 配置的方式配置 Spring?
- 9、怎樣用注解的方式配置 Spring?
- 10、請解釋 Spring Bean 的生命周期?
- 11、Spring Bean 的作用域之間有什么區別?
- 12、什么是 Spring inner beans?
- 13、Spring 框架中的單例 Beans 是執行緒安全的么?
- 14、請舉例說明如何在 Spring 中注入一個 Java Collection?
- 15、如何向 Spring Bean 中注入一個 Java.util.Properties?
- 16、請解釋 Spring Bean 的自動裝配?
- 17、請解釋自動裝配模式的區別?
- 18、如何開啟基于注解的自動裝配?
- 19、請舉例解釋@Required 注解?
- 20、請舉例解釋@Autowired 注解?
- 21、請舉例說明@Qualifier 注解?
- 22、構造方法注入和設值注入有什么區別?
設計模式 10題
記得最清楚的是單例模式的懶漢和餓漢模式,這個考察的方向是一般是固定的,當然不排除面試官考察通知作業中遇到的問題(同學就是這樣,自己作業不會的就狂問應聘的,心疼面試人員),

- 1.請列舉出在 JDK 中幾個常用的設計模式?
- 2.什么是設計模式?你是否在你的代碼里面使用過任何設計模式?
- 3.Java 中什么叫單例設計模式?請用 Java 寫出執行緒安全的單例模式
- 4.在 Java 中,什么叫觀察者設計模式(observer design pattern)?
- 5.使用工廠模式最主要的好處是什么?在哪里使用?
- 6.舉一個用 Java 實作的裝飾模式(decorator design pattern)?它是作用于物件層次還是類
層次? - 7.在 Java 中,為什么不允許從靜態方法中訪問非靜態變數?
- 8.設計一個 ATM 機,請說出你的設計思路?
- 9.在 Java 中,什么時候用多載,什么時候用重寫?
- 10.舉例說明什么情況下會更傾向于使用抽象類而不是介面
springboot 22題
最近springboot和springcloud的占比越來越重,因為他們最受中小企業歡迎,學會了它們最低也餓不死了哈哈,

- 什么是 Spring Boot?
- Spring Boot 有哪些優點?
- 什么是 JavaConfig?
- 如何重新加載 Spring Boot 上的更改,而無需重新啟動服務器?
- Spring Boot 中的監視器是什么?
- 如何在 Spring Boot 中禁用 Actuator 端點安全性?
- 如何在自定義埠上運行 Spring Boot 應用程式?
- 什么是 YAML?
- 如何實作 Spring Boot 應用程式的安全性?
- 如何集成 Spring Boot 和 ActiveMQ?
- 如何使用 Spring Boot 實作分頁和排序?
- 什么是 Swagger?你用 Spring Boot 實作了它嗎?
- 什么是 Spring Profiles?
- 什么是 Spring Batch?
- 什么是 FreeMarker 模板?
- 如何使用 Spring Boot 實作例外處理?
- 您使用了哪些 starter maven 依賴項?
- 什么是 CSRF 攻擊?
- 什么是 WebSockets?
- 什么是 AOP?
- 什么是 Apache Kafka?
- 我們如何監視所有 Spring Boot 微服務?
Spring Cloud 8題
-
什么是 Spring Cloud?
-
使用 Spring Cloud 有什么優勢?
-
服務注冊和發現是什么意思?Spring Cloud 如何實作?
-
負載平衡的意義什么?
-
什么是 Hystrix?它如何實作容錯?
-
什么是 Hystrix 斷路器?我們需要它嗎?
-
什么是 Netflix Feign?它的優點是什么?
-
什么是 Spring Cloud Bus?我們需要它嗎?
Redis 8題
Redis的資料特點以及回收策略是很重要的一部分,它的優勢以及使用場景都需要了解一下

- 什么是redis?
- Reids的特點
- Redis支持的資料型別
- Redis是單行程單執行緒的
- 虛擬記憶體
- Redis鎖
- 讀寫分離模型
- 資料分片模型
一線互聯網企業精品面試題73道
- junit 用法,before,beforeClass,after, afterClass 的執行順序
- 分布式鎖
- nginx 的請求轉發演算法,如何配置根據權重轉發
- 用 hashmap 實作 redis 有什么問題(死鎖,死回圈,可用 ConcurrentH ashmap)
- 執行緒的狀態
- 執行緒的阻塞的方式
- sleep 和 wait 的區別
- hashmap 的底層實作
- 一萬個人搶 100 個紅包,如何實作(不用佇列),如何保證 2 個人不能搶到同一個紅包,可用分布式鎖
- java 記憶體模型,垃圾回識訓制,不可達演算法
- 兩個 Integer 的參考物件傳給一個 swap 方法在方法內部交換參考,回傳后,兩個參考的值是否會發現變化
- aop 的底層實作,動態代理是如何動態,假如有 100 個物件,如何動態 的為這 100 個物件代理
- 是否用過 maven install, maven test,git(make install 是安裝本地 jar 包)
-
tomcat 的各種配置,如何配置 docBase
-
spring 的 bean 配置的幾種方式
- web.xml 的配置
- spring 的監聽器,
- zookeeper 的實作機制,有快取,如何存盤注冊服務的
- IO 會阻塞嗎?readLine 是不是阻塞的
- 用過 spring 的執行緒池還是 java 的執行緒池?
- 字串的格式化方法 (20,21 這兩個問題問的太低級了)
- 時間的格式化方法
- 定時器用什么做的
- 執行緒如何退出結束
- java 有哪些鎖?樂觀鎖 悲觀鎖 synchronized 可重入鎖 讀寫鎖,用過 reentrantlock 嗎?reentrantlock 與 synmchronized 的區別
- ThreadLocal 的使用場景
- java 的記憶體模型,垃圾回識訓制
- 為什么執行緒執行要呼叫 start 而不是直接 run(直接 run,跟普通方法沒 什么區別,先調 start,run 才會作為一個執行緒方法運行)
- qmq 訊息的實作機制(qmq 是去哪兒網自己封裝的訊息佇列)
- 遍歷 hashmap 的三種方式
- jvm 的一些命令31. memcache 和 redis 的區別
- mysql 的行級鎖加在哪個位置
- ConcurrentHashmap 的鎖是如何加的?是不是分段越多越好
- myisam 和 innodb 的區別(innodb 是行級鎖,myisam 是表級鎖)
- mysql 其他的性能優化方式
- linux 系統日志在哪里看
- 如何查看網路行程
- 統計一個整數的二進制表示中 bit 為 1 的個數
- jvm 記憶體模型,java 記憶體模型
- 如何把 java 記憶體的資料全部 dump 出來
- 如何手動觸發全量回收垃圾,如何立即觸發垃圾回收
- hashmap 如果只有一個寫其他全讀會出什么問題
- mybatis 如何映射表結構
- 二叉樹遍歷
- 主從復制
- mysql 引擎區別
- 靜態內部類加載到了哪個區?方法區
- class 檔案編譯后加載到了哪
- web 的 http 請求如何整體回應時間變長導致處理的請求數變少,該如何處理?用佇列,當處理不了那么多 http 請求時將請求放到佇列中慢慢處理,web 如何實作佇列77. 執行緒安全的單例模式
- 快速排序性能考慮
- volatile 關鍵字用法
- 求表的 size,或做資料統計可用什么存盤引擎
- 讀多寫少可用什么引擎
- 假如要統計多個表應該用什么引擎
- concurrenhashmap 求 size 是如何加鎖的,如果剛求完一段后這段發生了變化該如何處理1000 個蘋果放 10 個籃子,怎么放,能讓我拿到所有可能的個數可重入的讀寫鎖,可重入是如何實作的?
- 是否用過 NIO
- java 的 concurrent 包用過沒
- sting s=new string("abc")分別在堆疊上新建了哪些物件
- java 虛擬機的區域分配,各區分別存什么
- 分布式事務(JTA)91. threadlocal 使用時注意的問題(ThreadLocal 和 Synchonized 都用于解決多執行緒并發訪問,但是 ThreadLocal 與 synchronized 有本質的區別,s
- ynchronized 是利用鎖的機制,使變數或代碼塊在某一時該只能被一個執行緒訪問,而 ThreadLocal 為每一個執行緒都提供了變數的副本,使得每個執行緒在某 一時間訪問到的并不是同一個物件,這樣就隔離了多個執行緒對資料的資料共享,而 Synchronized 卻正好相反,它用于在多個執行緒間通信時能夠獲得資料共享)
- java 有哪些容器(集合,tomcat 也是一種容器)
- 二分查找演算法
- myisam 的優點,和 innodb 的區別
- redis 能存哪些型別
- http 協議格式,get 和 post 的區別
- 可重入鎖中對應的 wait 和 notify
- redis 能把記憶體空間交換進磁盤中嗎(這個應該是可以的,但是那個面試官 非跟我說不可以)
- java 執行緒池中基于快取和基于定長的兩種執行緒池,當請求太多時分別是如何處理的?定長的事用的佇列,如果佇列也滿了呢?交換進磁盤?基于快取的 執行緒池解決方法呢?
- synchronized 加在方法上用的什么鎖101. 可重入鎖中的 lock 和 trylock 的區別
- innodb 對一行資料的讀會枷鎖嗎?不枷鎖,讀實際讀的是副本
- redis 做快取是分布式存的?不同的服務器上存的資料是否重復?guava

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/123676.html
標籤:其他
上一篇:2006-京淘Day02-3

