2020年最新干貨,Java面試題總結

2020年最新干貨,Java面試題總結

天津卓眾教育      2022-04-24 17:56:01     20

2020年最新干貨,Java面試題總結,  很多人在找工作之前都會做不少的準備,有一份全面細致的面試題會給大家減少很多麻煩,所以準備找工作的同學可以參考看看: 

課程價格 請咨詢

上課時段: 授課校區(qū):

詳細介紹

 

  很多人在找工作之前都會做不少的準備,有一份全面細致的面試題會給大家減少很多麻煩,所以準備找工作的同學可以參考看看:

  ThreadLocal(線程變量副本)

  Synchronized實現(xiàn)內存共享,ThreadLocal為每個線程維護一個本地變量。

  采用空間換時間,它用于線程間的數(shù)據(jù)隔離,為每一個使用該變量的線程提供一個副本,每個線程都可以獨立地改變自己的副本,而不會和其他線程的副本沖突。

  ThreadLocal類中維護一個Map,用于存儲每一個線程的變量副本,Map中元素的鍵為線程對象,而值為對應線程的變量副本。

  ThreadLocal在Spring中發(fā)揮著巨大的作用,在管理Request作用域中的Bean、事務管理、任務調度、AOP等模塊都出現(xiàn)了它的身影。

  Spring中絕大部分Bean都可以聲明成Singleton作用域,采用ThreadLocal進行封裝,因此有狀態(tài)的Bean就能夠以singleton的方式在多線程中正常工作了。

  “你能不能談談,java GC是在什么時候,對什么東西,做了什么事情?”

  在什么時候:

  1、新生代有一個Eden區(qū)和兩個survivor區(qū),首先將對象放入Eden區(qū),如果空間不足就向其中的一個survivor區(qū)上放,如果仍然放不下就會引發(fā)一次發(fā)生在新生代的minor GC,將存活的對象放入另一個survivor區(qū)中,然后清空Eden和之前的那個survivor區(qū)的內存。在某次GC過程中,如果發(fā)現(xiàn)仍然又放不下的對象,就將這些對象放入老年代內存里去。

  2、大對象以及長期存活的對象直接進入老年區(qū)。

  3、當每次執(zhí)行minor GC的時候應該對要晉升到老年代的對象進行分析,如果這些馬上要到老年區(qū)的老年對象的大小超過了老年區(qū)的剩余大小,那么執(zhí)行一次Full GC以盡可能地獲得老年區(qū)的空間。

  對什么東西:

  從GC Roots搜索不到,而且經(jīng)過一次標記清理之后仍沒有復活的對象。

  做什么:

  新生代:復制清理; 老年代:標記-清除和標記-壓縮算法; 永久代:存放Java中的類和加載類的類加載器本身。

  GC Roots都有哪些: 1. 虛擬機棧中的引用的對象 2. 方法區(qū)中靜態(tài)屬性引用的對象,常量引用的對象 3. 本地方法棧中JNI(即一般說的Native方法)引用的對象。

 

 

  Synchronized 與Loc

  Synchronized 與Lock都是可重入鎖,同一個線程再次進入同步代碼的時候??梢允褂米约阂呀?jīng)獲取到的鎖。

  Synchronized是悲觀鎖機制,獨占鎖。而Locks.ReentrantLock是,每次不加鎖而是假設沒有沖突而去完成某項操作,如果因為沖突失敗就重試,直到成功為止。

  ReentrantLock適用場景

  1、某個線程在等待一個鎖的控制權的這段時間需要中斷;

  2、需要分開處理一些wait-notify,ReentrantLock里面的Condition應用,能夠控制notify哪個線程,鎖可以綁定多個條件;

  3、具有公平鎖功能,每個到來的線程都將排隊等候。

  StringBuffer是線程安全的,每次操作字符串,String會生成一個新的對象,而StringBuffer不會;StringBuilder是非線程安全的。

  fail-fast是什么?

  fail-fast:機制是java集合(Collection)中的一種錯誤機制。當多個線程對同一個集合的內容進行操作時,就可能會產(chǎn)生fail-fast事件。

  例如:當某一個線程A通過iterator去遍歷某集合的過程中,若該集合的內容被其他線程所改變了;那么線程A訪問集合時,就會拋出ConcurrentModificationException異常,產(chǎn)生fail-fast事件。

  happens-before

  happens-before:如果兩個操作之間具有 happens-before 關系,那么前一個操作的結果就會對后面一個操作可見。

  1、程序順序規(guī)則:一個線程中的每個操作,happens- before 于該線程中的任意后續(xù)操作。

  2、監(jiān)視器鎖規(guī)則:對一個監(jiān)視器鎖的解鎖,happens- before 于隨后對這個監(jiān)視器鎖的加鎖。

  3、volatile變量規(guī)則:對一個volatile域的寫,happens- before于任意后續(xù)對這個volatile域的讀。

  4、傳遞性:如果A happens- before B,且B happens- before C,那么A happens- before C。

  5、線程啟動規(guī)則:Thread對象的start()方法happens- before于此線程的每一個動作。

  Volatile和Synchronized的不同點

  Volatile和Synchronized四個不同點:

  1、粒度不同,前者針對變量 ,后者鎖對象和類;

  2、syn阻塞,volatile線程不阻塞;

  3、syn保證三大特性,volatile不保證原子性;

  4、syn編譯器優(yōu)化,volatile不優(yōu)化 volatile具備兩種特性:

  保證此變量對所有線程的可見性,指一條線程修改了這個變量的值,新值對于其他線程來說是可見的,但并不是多線程安全的;

  禁止指令重排序優(yōu)化。

  Volatile如何保證內存可見性:

  1、當寫一個volatile變量時,JMM會把該線程對應的本地內存中的共享變量刷新到主內存。

  2、當讀一個volatile變量時,JMM會把該線程對應的本地內存置為無效。線程接下來將從主內存中讀取共享變量。

  同步:就是一個任務的完成需要依賴另外一個任務,只有等待被依賴的任務完成后,依賴任務才能完成。

  異步:不需要等待被依賴的任務完成,只是通知被依賴的任務要完成什么工作,只要自己任務完成了就算完成了,被依賴的任務是否完成會通知回來。(異步的特點就是通知)。 打電話和發(fā)短信來比喻同步和異步操作。

  阻塞:CPU停下來等一個慢的操作完成以后,才會接著完成其他的工作。

  非阻塞:非阻塞就是在這個慢的執(zhí)行時,CPU去做其他工作,等這個慢的完成后,CPU才會接著完成后續(xù)的操作。

  非阻塞會造成線程切換增加,增加CPU的使用時間能不能補償系統(tǒng)的切換成本需要考慮。

 

 

  CAS

  CAS(Compare And Swap) 無鎖算法: CAS是樂觀鎖技術,當多個線程嘗試使用CAS同時更新同一個變量時,只有其中一個線程能更新變量的值,而其它線程都失敗,失敗的線程并不會被掛起,而是被告知這次競爭中失敗,并可以再次嘗試。

  CAS有3個操作數(shù),內存值V,舊的預期值A,要修改的新值B。當且僅當預期值A和內存值V相同時,將內存值V修改為B,否則什么都不做。

  類加載器工作機制

  裝載:將Java二進制代碼導入jvm中,生成Class文件。

  連接:

  a)校驗:檢查載入Class文件數(shù)據(jù)的正確性;

  b)準備:給類的靜態(tài)變量分配存儲空間;

  c)解析:將符號引用轉成直接引用。

  初始化:對類的靜態(tài)變量,靜態(tài)方法和靜態(tài)代碼塊執(zhí)行初始化工作。

  雙親委派模型:類加載器收到類加載請求,首先將請求委派給父類加載器完成,用戶自定義加載器->應用程序加載器->擴展類加載器->啟動類加載器。

  Redis數(shù)據(jù)結構

  String—字符串(key-value 類型)

  Hash—字典(hashmap) Redis的哈希結構可以使你像在數(shù)據(jù)庫中更新一個屬性一樣只修改某一項屬性值

  List—列表 實現(xiàn)消息隊列

  Set—集合 利用唯一性

  Sorted Set—有序集合 可以進行排序 可以實現(xiàn)數(shù)據(jù)持久化

  索引:B+,B-,全文索引

  Mysql的索引是一個數(shù)據(jù)結構,旨在使數(shù)據(jù)庫高效的查找數(shù)據(jù)。

  常用的數(shù)據(jù)結構是B+Tree,每個葉子節(jié)點不但存放了索引鍵的相關信息還增加了指向相鄰葉子節(jié)點的指針,這樣就形成了帶有順序訪問指針的B+Tree,做這個優(yōu)化的目的是提高不同區(qū)間訪問的性能。

  什么時候使用索引:

  1、經(jīng)常出現(xiàn)在group by,order by和distinc關鍵字后面的字段。

  2、經(jīng)常與其他表進行連接的表,在連接字段上應該建立索引。

  3、經(jīng)常出現(xiàn)在Where子句中的字段。

  4、經(jīng)常出現(xiàn)用作查詢選擇的字段。

  Spring IOC

  Spring支持三種依賴注入方式,分別是屬性(Setter方法)注入,構造注入和接口注入。

  在Spring中,那些組成應用的主體及由Spring IOC容器所管理的對象被稱之為Bean。

  Spring的IOC容器通過反射的機制實例化Bean并建立Bean之間的依賴關系。

  簡單地講,Bean就是由Spring IOC容器初始化、裝配及被管理的對象。

  獲取Bean對象的過程,首先通過Resource加載配置文件并啟動IOC容器,然后通過getBean方法獲取bean對象,就可以調用他的方法。

  Spring Bean的作用域:

  Singleton:Spring IOC容器中只有一個共享的Bean實例,一般都是Singleton作用域。

  Prototype:每一個請求,會產(chǎn)生一個新的Bean實例。

  Request:每一次http請求會產(chǎn)生一個新的Bean實例。

 

 

      以上就是天津卓眾教育Java培訓機構小編介紹的“2020年最新干貨,Java面試題總結”的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務。

 

相關推薦

最新最全java面試題及答案(初級到高級)

史上最全的中高級JAVA工程師面試題及答案匯總

Java高級開發(fā)工程師面試題

2019史上最全java面試題題庫大全800題

哪有資深java工程師面試題

 

Java面試題

培訓啦提醒您:交易時請核實對方資質,對于過大宣傳或承諾需謹慎!任何要求預付定金、匯款等方式均存在風險,謹防上當。