更新時間:2019-12-16 14:42:12 來源:動力節點 瀏覽2248次
很多人在找工作之前都會做不少的準備,有一份全面細致的面試題會給大家減少很多麻煩,所以準備找工作的同學可以參考看看:
ThreadLocal(線程變量副本)
Synchronized實現內存共享,ThreadLocal為每個線程維護一個本地變量。
采用空間換時間,它用于線程間的數據隔離,為每一個使用該變量的線程提供一個副本,每個線程都可以獨立地改變自己的副本,而不會和其他線程的副本沖突。
ThreadLocal類中維護一個Map,用于存儲每一個線程的變量副本,Map中元素的鍵為線程對象,而值為對應線程的變量副本。
ThreadLocal在Spring中發揮著巨大的作用,在管理Request作用域中的Bean、事務管理、任務調度、AOP等模塊都出現了它的身影。
Spring中絕大部分Bean都可以聲明成Singleton作用域,采用ThreadLocal進行封裝,因此有狀態的Bean就能夠以singleton的方式在多線程中正常工作了。
“你能不能談談,java GC是在什么時候,對什么東西,做了什么事情?”
在什么時候:
1、新生代有一個Eden區和兩個survivor區,首先將對象放入Eden區,如果空間不足就向其中的一個survivor區上放,如果仍然放不下就會引發一次發生在新生代的minor GC,將存活的對象放入另一個survivor區中,然后清空Eden和之前的那個survivor區的內存。在某次GC過程中,如果發現仍然又放不下的對象,就將這些對象放入老年代內存里去。
2、大對象以及長期存活的對象直接進入老年區。
3、當每次執行minor GC的時候應該對要晉升到老年代的對象進行分析,如果這些馬上要到老年區的老年對象的大小超過了老年區的剩余大小,那么執行一次Full GC以盡可能地獲得老年區的空間。
對什么東西:
從GC Roots搜索不到,而且經過一次標記清理之后仍沒有復活的對象。
做什么:
新生代:復制清理; 老年代:標記-清除和標記-壓縮算法; 永久代:存放Java中的類和加載類的類加載器本身。
GC Roots都有哪些: 1. 虛擬機棧中的引用的對象 2. 方法區中靜態屬性引用的對象,常量引用的對象 3. 本地方法棧中JNI(即一般說的Native方法)引用的對象。
Synchronized 與Loc
Synchronized 與Lock都是可重入鎖,同一個線程再次進入同步代碼的時候。可以使用自己已經獲取到的鎖。
Synchronized是悲觀鎖機制,獨占鎖。而Locks.ReentrantLock是,每次不加鎖而是假設沒有沖突而去完成某項操作,如果因為沖突失敗就重試,直到成功為止。
ReentrantLock適用場景
1、某個線程在等待一個鎖的控制權的這段時間需要中斷;
2、需要分開處理一些wait-notify,ReentrantLock里面的Condition應用,能夠控制notify哪個線程,鎖可以綁定多個條件;
3、具有公平鎖功能,每個到來的線程都將排隊等候。
StringBuffer是線程安全的,每次操作字符串,String會生成一個新的對象,而StringBuffer不會;StringBuilder是非線程安全的。
fail-fast是什么?
fail-fast:機制是java集合(Collection)中的一種錯誤機制。當多個線程對同一個集合的內容進行操作時,就可能會產生fail-fast事件。
例如:當某一個線程A通過iterator去遍歷某集合的過程中,若該集合的內容被其他線程所改變了;那么線程A訪問集合時,就會拋出ConcurrentModificationException異常,產生fail-fast事件。
happens-before
happens-before:如果兩個操作之間具有 happens-before 關系,那么前一個操作的結果就會對后面一個操作可見。
1、程序順序規則:一個線程中的每個操作,happens- before 于該線程中的任意后續操作。
2、監視器鎖規則:對一個監視器鎖的解鎖,happens- before 于隨后對這個監視器鎖的加鎖。
3、volatile變量規則:對一個volatile域的寫,happens- before于任意后續對這個volatile域的讀。
4、傳遞性:如果A happens- before B,且B happens- before C,那么A happens- before C。
5、線程啟動規則:Thread對象的start()方法happens- before于此線程的每一個動作。
Volatile和Synchronized的不同點
Volatile和Synchronized四個不同點:
1、粒度不同,前者針對變量 ,后者鎖對象和類;
2、syn阻塞,volatile線程不阻塞;
3、syn保證三大特性,volatile不保證原子性;
4、syn編譯器優化,volatile不優化 volatile具備兩種特性:
保證此變量對所有線程的可見性,指一條線程修改了這個變量的值,新值對于其他線程來說是可見的,但并不是多線程安全的;
禁止指令重排序優化。
Volatile如何保證內存可見性:
1、當寫一個volatile變量時,JMM會把該線程對應的本地內存中的共享變量刷新到主內存。
2、當讀一個volatile變量時,JMM會把該線程對應的本地內存置為無效。線程接下來將從主內存中讀取共享變量。
同步:就是一個任務的完成需要依賴另外一個任務,只有等待被依賴的任務完成后,依賴任務才能完成。
異步:不需要等待被依賴的任務完成,只是通知被依賴的任務要完成什么工作,只要自己任務完成了就算完成了,被依賴的任務是否完成會通知回來。(異步的特點就是通知)。 打電話和發短信來比喻同步和異步操作。
阻塞:CPU停下來等一個慢的操作完成以后,才會接著完成其他的工作。
非阻塞:非阻塞就是在這個慢的執行時,CPU去做其他工作,等這個慢的完成后,CPU才會接著完成后續的操作。
非阻塞會造成線程切換增加,增加CPU的使用時間能不能補償系統的切換成本需要考慮。
CAS
CAS(Compare And Swap) 無鎖算法: CAS是樂觀鎖技術,當多個線程嘗試使用CAS同時更新同一個變量時,只有其中一個線程能更新變量的值,而其它線程都失敗,失敗的線程并不會被掛起,而是被告知這次競爭中失敗,并可以再次嘗試。
CAS有3個操作數,內存值V,舊的預期值A,要修改的新值B。當且僅當預期值A和內存值V相同時,將內存值V修改為B,否則什么都不做。
類加載器工作機制
裝載:將Java二進制代碼導入jvm中,生成Class文件。
連接:
a)校驗:檢查載入Class文件數據的正確性;
b)準備:給類的靜態變量分配存儲空間;
c)解析:將符號引用轉成直接引用。
初始化:對類的靜態變量,靜態方法和靜態代碼塊執行初始化工作。
雙親委派模型:類加載器收到類加載請求,首先將請求委派給父類加載器完成,用戶自定義加載器->應用程序加載器->擴展類加載器->啟動類加載器。
Redis數據結構
String—字符串(key-value 類型)
Hash—字典(hashmap) Redis的哈希結構可以使你像在數據庫中更新一個屬性一樣只修改某一項屬性值
List—列表 實現消息隊列
Set—集合 利用唯一性
Sorted Set—有序集合 可以進行排序 可以實現數據持久化
索引:B+,B-,全文索引
Mysql的索引是一個數據結構,旨在使數據庫高效的查找數據。
常用的數據結構是B+Tree,每個葉子節點不但存放了索引鍵的相關信息還增加了指向相鄰葉子節點的指針,這樣就形成了帶有順序訪問指針的B+Tree,做這個優化的目的是提高不同區間訪問的性能。
什么時候使用索引:
1、經常出現在group by,order by和distinc關鍵字后面的字段。
2、經常與其他表進行連接的表,在連接字段上應該建立索引。
3、經常出現在Where子句中的字段。
4、經常出現用作查詢選擇的字段。
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:每一個請求,會產生一個新的Bean實例。
Request:每一次http請求會產生一個新的Bean實例。
以上就是動力節點Java培訓機構小編介紹的“2020年最新干貨,Java面試題總結”的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業老師隨時為你服務。
相關推薦
最新最全java面試題及答案(初級到高級)
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習