這篇文章主要介紹“JVM的class裝載是什么意思”,在日常操作中,相信很多人在JVM的class裝載是什么意思問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JVM的class裝載是什么意思”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
成都創(chuàng)新互聯(lián)是一家專業(yè)提供濮陽企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)、H5場景定制、小程序制作等業(yè)務(wù)。10年已為濮陽眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計(jì)公司優(yōu)惠進(jìn)行中。
主動使用 class時
創(chuàng)建一個類的實(shí)例 (new 、反射、克隆、反序列化)
調(diào)用類的靜態(tài)方法(invokestatic)
使用類或接口的靜態(tài)字段(getstatic、putstatic)
使用 reflect反射
初始化子類,先初始化父類
main方法的類
被動引用不會初始化類
package com.mousycoder.mycode.thinking_in_jvm; /** * @version 1.0 * @author: mousycoder * @date: 2019-09-02 16:29 */ public class Parent { static { System.out.println("Parent init"); } public static int v = 100; } package com.mousycoder.mycode.thinking_in_jvm; import sun.jvm.hotspot.memory.ParNewGeneration; /** * @version 1.0 * @author: mousycoder * @date: 2019-09-02 16:29 */ public class Child extends Parent { static { System.out.println("Child init"); } } package com.mousycoder.mycode.thinking_in_jvm; /** * @version 1.0 * @author: mousycoder * @date: 2019-09-02 16:32 */ public class UseParent { public static void main(String[] args) { System.out.println(Child.v); } }
虛擬機(jī)參數(shù) -XX:+TraceClassLoading
輸出
[Loaded com.mousycoder.mycode.thinking_in_jvm.Parent from file:/Users/mousycoder/My/code/mycode/target/classes/] [Loaded com.mousycoder.mycode.thinking_in_jvm.Child from file:/Users/mousycoder/My/code/mycode/target/classes/] Parent init 100 [Loaded java.lang.Shutdown from /Library/Java/JavaVirtualMachines/jdk1.8.0.jdk/Contents/Home/jre/lib/rt.jar] [Loaded java.lang.Shutdown$Lock from /Library/Java/JavaVirtualMachines/jdk1.8.0.jdk/Contents/Home/jre/lib/rt.jar]
表示 Child被加載了,但是沒有被初始化
final 常量不會引起類初始化
package com.mousycoder.mycode.thinking_in_jvm; /** * @version 1.0 * @author: mousycoder * @date: 2019-09-02 16:41 */ public class FinalFieldClass { public static final String constString = "CONST"; static { System.out.println("FinalFieldClass init"); } } package com.mousycoder.mycode.thinking_in_jvm; public class UseFinalField { public static void main(String[] args) { System.out.println(FinalFieldClass.constString); } }
輸出
CONST
FinalFieldClass 類沒有因?yàn)槌A?constString 被引用而初始化,而是直接把CONST 放在常量池中
例子:加載String類
package com.mousycoder.mycode.thinking_in_jvm; import java.lang.reflect.Method; import java.lang.reflect.Modifier; /** * @version 1.0 * @author: mousycoder * @date: 2019-09-03 13:38 */ public class StringTest { public static void main(String[] args) throws ClassNotFoundException { Class clzStr = Class.forName("java.lang.String"); Method[] ms = clzStr.getDeclaredMethods(); for (Method m : ms) { String mod = Modifier.toString(m.getModifiers()); System.out.println(mod + " " + m.getName() + " ( "); Class>[] ps = m.getParameterTypes(); if (ps.length == 0 ){ System.out.println(')'); } for (int i = 0; i < ps.length; i++) { char end =i==ps.length-1 ? ')':','; System.out.println(ps[i].getSimpleName() + end); } System.out.println(); } } }
輸出 `` public equals ( Object)
public toString ( )
public hashCode ( )
public volatile compareTo ( Object)
public compareTo ( String)
public indexOf ( String, int)` ``
保證加載的字節(jié)碼合法
為類分配對應(yīng)的內(nèi)存空間,并設(shè)置初始值,此階段不會有 java 代碼執(zhí)行 |類型|默認(rèn)初始值| |--|--| |int|0| |long|0L| |short|(short)0| |char|\u0000| |boolean|false| |reference|null| |float|0f| |double|0f|
將類、接口、字段、方法的符號引用(字面量的引用)轉(zhuǎn)成直接引用(找到方法中表的位置)
執(zhí)行類的初始化方法
到此,關(guān)于“JVM的class裝載是什么意思”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!