更新時間:2020-02-20 12:39:36 來源:動力節(jié)點 瀏覽2301次
JVM的類加載機制是什么?有哪些實現(xiàn)方式?
類加載機制:
類的加載指的是將類的.class文件中的二進制數(shù)據(jù)讀入到內存中,將其放在運行時數(shù)據(jù)區(qū)的方法去內,然后在堆區(qū)創(chuàng)建一個java.lang.Class對象,用來封裝在方法區(qū)內的數(shù)據(jù)結構。類的加載最終是在堆區(qū)內的Class對象,Class對象封裝了類在方法區(qū)內的數(shù)據(jù)結構,并且向Java程序員提供了訪問方法區(qū)內的數(shù)據(jù)結構的接口。
類加載有三種方式:
命令行啟動應用時候由JVM初始化加載
通過Class.forName()方法動態(tài)加載
通過ClassLoader.loadClass()方法動態(tài)加載
JVM的常見垃圾回收算法?
標記-清楚算法:前后線標記處所有需要回收的對象,在標記完成后統(tǒng)一回收有被標記的對象。
復制算法:將可用內存按容量劃分為大小相等的兩塊,每次只使用其中的一塊。當一塊內存用完了,將其存在另外一塊上面,然后再把已使用過的內存空間一次清理掉。
標記-整理算法:標記過程與“標記-清除”算法一樣,但后續(xù)步驟不是直接對可回收對象進行清理,而是讓所一端移動,然后直接清理掉端邊界以外的內存。
分代收集算法:一般是把Java堆分為新生代和老年代,根據(jù)各個年代的特點采用最適當?shù)氖占惴āP律及l(fā)現(xiàn)有大批對象死去,選用復制算法。老年代中因為對象存活率高,必須使用“標記-清理”或“標記-整理”算法來進行回收。
JVM調優(yōu)的常見命令行工具有哪些?JVM常見的調優(yōu)參數(shù)有哪些?
(1)JVM調優(yōu)的常見命令工具包括:
jps命令用于查詢正在運行的JVM進程,
jstat可以實時顯示本地或遠程JVM進程中類裝載、內存、垃圾收集、JIT編譯等數(shù)據(jù)
jinfo用于查詢當前運行這的JVM屬性和參數(shù)的值。
jmap用于顯示當前Java堆和永久代的詳細信息
jhat用于分析使用jmap生成的dump文件,是JDK自帶的工具
jstack用于生成當前JVM的所有線程快照,線程快照是虛擬機每一條線程正在執(zhí)行的方法,目的是定位線程出現(xiàn)長時間停頓的原因。
(2)JVM常見的調優(yōu)參數(shù)包括:
-Xmx
指定java程序的最大堆內存,使用java-Xmx5000M-version判斷當前系統(tǒng)能分配的最大堆內存
-Xms
指定最小堆內存,通常設置成跟最大堆內存一樣,減少GC
-Xmn
設置年輕代大小。整個堆大小=年輕代大小+年老代大小。所以增大年輕代后,將會減小年老代大小。此值對系統(tǒng)性能影響較大,Sun官方推薦配置為整個堆的3/8。
-Xss
指定線程的最大棧空間,此參數(shù)決定了java函數(shù)調用的深度,值越大調用深度越深,若值太小則容易出棧溢出錯誤(StackOverflowError)
-XX:PermSize
指定方法區(qū)(永久區(qū))的初始值,默認是物理內存的1/64,在Java8永久區(qū)移除,代之的是元數(shù)據(jù)區(qū),由-XX:MetaspaceSize指定
-XX:MaxPermSize
指定方法區(qū)的最大值,默認是物理內存的1/4,在java8中由-XX:MaxMetaspaceSize指定元數(shù)據(jù)區(qū)的大小
-XX:NewRatio=n
年老代與年輕代的比值,-XX:NewRatio=2,表示年老代與年輕代的比值為2:1
-XX:SurvivorRatio=n
Eden區(qū)與Survivor區(qū)的大小比值,-XX:SurvivorRatio=8表示Eden區(qū)與Survivor區(qū)的大小比值是8:1:1,因為Survivor區(qū)有兩個(from,to)
ConcurrentHashMap加鎖機制是什么,詳細說一下?
HashTable容器在競爭激烈的并發(fā)環(huán)境下表現(xiàn)出效率低下的原因,是因為所有訪問HashTable的線程都必須競爭同一把鎖,那假如容器里有多把鎖,每一把鎖用于鎖容器其中一部分數(shù)據(jù),那么當多線程訪問容器里不同數(shù)據(jù)段的數(shù)據(jù)時,線程間就不會存在鎖競爭,從而可以有效的提高并發(fā)訪問效率,這就是ConcurrentHashMap所使用的鎖分段技術,首先將數(shù)據(jù)分成一段一段的存儲,然后給每一段數(shù)據(jù)配一把鎖,當一個線程占用鎖訪問其中一個段數(shù)據(jù)的時候,其他段的數(shù)據(jù)也能被其他線程訪問。
G1收集器簡介?以及它的內存劃分怎么樣的?
(1)簡介:
Garbage-First(G1,垃圾優(yōu)先)收集器是服務類型的收集器,目標是多處理器機器、大內存機器。它高度符合垃圾收集暫停時間的目標,同時實現(xiàn)高吞吐量。OracleJDK7update4以及更新發(fā)布版完全支持G1垃圾收集器
(2)G1的內存劃分方式:
它是將堆內存被劃分為多個大小相等的heap區(qū),每個heap區(qū)都是邏輯上連續(xù)的一段內存(virtualmemory).其中一部分區(qū)域被當成老一代收集器相同的角色(eden,survivor,old),但每個角色的區(qū)域個數(shù)都不是固定的。這在內存使用上提供了更多的靈活性
在重寫equals方法時,需要遵循哪些約定,具體介紹一下?
重寫equals方法時需要遵循通用約定:自反性、對稱性、傳遞性、一致性.、非空性
1)自反性
對于任何非null的引用值x,x.equals(x)必須返回true。---這一點基本上不會有啥問題
2)對稱性
對于任何非null的引用值x和y,當且僅當x.equals(y)為true時,y.equals(x)也為true。
3)傳遞性
對于任何非null的引用值x、y、z。如果x.equals(y)==true,y.equals(z)==true,那么x.equals(z)==true。
4)一致性
對于任何非null的引用值x和y,只要equals的比較操作在對象所用的信息沒有被修改,那么多次調用x.eqals(y)就會一致性地返回true,或者一致性的返回false。
5)非空性
所有比較的對象都不能為空。
Synchronized優(yōu)化后的鎖機制簡單介紹一下,包括自旋鎖、偏向鎖、輕量級鎖、重量級鎖?
自旋鎖:
線程自旋說白了就是讓cup在做無用功,比如:可以執(zhí)行幾次for循環(huán),可以執(zhí)行幾條空的匯編指令,目的是占著CPU不放,等待獲取鎖的機會。如果旋的時間過長會影響整體性能,時間過短又達不到延遲阻塞的目的。
偏向鎖:
偏向鎖就是一旦線程第一次獲得了監(jiān)視對象,之后讓監(jiān)視對象“偏向”這個線程,之后的多次調用則可以避免CAS操作,
說白了就是置個變量,如果發(fā)現(xiàn)為true則無需再走各種加鎖/解鎖流程。
輕量級鎖:
輕量級鎖是由偏向所升級來的,偏向鎖運行在一個線程進入同步塊的情況下,當?shù)诙€線程加入鎖爭用的時候,偏向鎖就會升級為輕量級鎖;
重量級鎖:
重量鎖在JVM中又叫對象監(jiān)視器(Monitor),它很像C中的Mutex,除了具備Mutex(0|1)互斥的功能,它還負責實現(xiàn)了Semaphore(信號量)的功能,也就是說它至少包含一個競爭鎖的隊列,和一個信號阻塞隊列(wait隊列),前者負責做互斥,后一個用于做線程同步。
偏向鎖、輕量級鎖、重量級鎖的對比:
以上就是動力節(jié)點Java培訓機構小編介紹的“精選Java面試題目及最佳答案!”的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務。
相關推薦