導航:首頁 > 編程語言 > java類載入編譯

java類載入編譯

發布時間:2022-05-31 11:24:06

java中的「類」是什麼時候被載入到虛擬機

1、編譯和運行概念要搞清:編譯即javac的過程,負責將.java文件compile成.class文件,主要是類型、格式檢查與編譯成位元組碼文件,而載入是指java *的過程,將.class文件載入到內存中去解釋執行,即運行的時候才會有載入一說。

2、類的載入時機,肯定是在運行時,但並不是一次性全部載入,而是按需動態,依靠反射來實現動態載入,一般來說一個class只會被載入一次,之後就會從jvm的class實例的緩存中獲取,誰用誰取就可以了,不會再去文件系統中載入.class文件了。

② Java中類載入出現在哪個階段,編譯期和運行期 類載入和類裝載是一樣的嗎

使用的類,編譯/運行時都會被載入。

載入/裝載沒有區別,翻譯的詞彙選擇因人而異了

運行 javac /java 時 加上 -verbose 選項就可以看到了。

③ 怎麼理解java中的靜態載入類和動態載入類

一.什麼是動態載入類 什麼是靜態載入類

Class.forName 不僅表示類的類類型,還代表了動態載入類。編譯時載入是靜態載入類,

運行時載入是動態載入類。

二.為何要使用動態載入類

我們寫了一個程序 並沒有寫A類和B類以及start方法?

④ java 類載入先後順序

1.父類靜態代碼塊;
2.子類靜態代碼塊;
3.父類非靜態代碼塊;
4.父類構造函數;
5.子類非靜態代碼塊;
6.子類構造函數;

舉例:
public class ExA {
static {
System.out.println("父類靜態代碼塊。");
}
public ExA() {
System.out.println("父類構造函數。");
}
{
System.out.println("父類非靜態代碼塊。");
}

public static void main(String[] args) {
new ExB();
}
}
class ExB extends ExA {
static {
System.out.println("子類靜態代碼塊。");
}
{
System.out.println("子類非靜態代碼塊。");
}
public ExB() {
System.out.println("子類構造函數。");
}
}
執行結果:父類靜態代碼塊。子類靜態代碼塊。父類非靜態代碼塊。父類構造函數。子類非靜態代碼塊。子類構造函數。

⑤ java 類載入機制有什麼用

AVA類載入機制詳解

「代碼編譯的結果從本地機器碼轉變為位元組碼,是存儲格式發展的一小步,卻是變成語言發展的一大步」,這句話出自《深入理解JAVA虛擬機》一書,後面關於jvm的系列文章主要都是參考這本書。

JAVA源碼編譯由三個過程組成:

1、源碼編譯機制。

2、類載入機制

3、類執行機制

我們這里主要介紹編譯和類載入這兩種機制。

一、源碼編譯

代碼編譯由JAVA源碼編譯器來完成。主要是將源碼編譯成位元組碼文件(class文件)。位元組碼文件格式主要分為兩部分:常量池和方法位元組碼。

二、類載入

類的生命周期是從被載入到虛擬機內存中開始,到卸載出內存結束。過程共有七個階段,其中到初始化之前的都是屬於類載入的部分

載入----驗證----准備----解析-----初始化----使用-----卸載

系統可能在第一次使用某個類時載入該類,也可能採用預載入機制來載入某個類,當運行某個java程序時,會啟動一個java虛擬機進程,兩次運行的java程序處於兩個不同的JVM進程中,兩個jvm之間並不會共享數據。

1、載入階段

這個流程中的載入是類載入機制中的一個階段,這兩個概念不要混淆,這個階段需要完成的事情有:

1)通過一個類的全限定名來獲取定義此類的二進制位元組流。

2)將這個位元組流所代表的靜態存儲結構轉化為方法區的運行時數據結構。

3)在java堆中生成一個代表這個類的Class對象,作為訪問方法區中這些數據的入口。

由於第一點沒有指明從哪裡獲取以及怎樣獲取類的二進制位元組流,所以這一塊區域留給我開發者很大的發揮空間。這個我在後面的類載入器中在進行介紹。

2、准備階段

這個階段正式為類變數(被static修飾的變數)分配內存並設置類變數初始值,這個內存分配是發生在方法區中。

1、注意這里並沒有對實例變數進行內存分配,實例變數將會在對象實例化時隨著對象一起分配在JAVA堆中。

2、這里設置的初始值,通常是指數據類型的零值。

private static int a = 3;

這個類變數a在准備階段後的值是0,將3賦值給變數a是發生在初始化階段。

3、初始化階段

初始化是類載入機制的最後一步,這個時候才正真開始執行類中定義的JAVA程序代碼。在前面准備階段,類變數已經賦過一次系統要求的初始值,在初始化階段最重要的事情就是對類變數進行初始化,關注的重點是父子類之間各類資源初始化的順序。

java類中對類變數指定初始值有兩種方式:1、聲明類變數時指定初始值;2、使用靜態初始化塊為類變數指定初始值。

初始化的時機

1)創建類實例的時候,分別有:1、使用new關鍵字創建實例;2、通過反射創建實例;3、通過反序列化方式創建實例。

new Test();
Class.forName(「com.mengdd.Test」);

2)調用某個類的類方法(靜態方法)

Test.doSomething();

3)訪問某個類或介面的類變數,或為該類變數賦值。

int b=Test.a;
Test.a=b;

4)初始化某個類的子類。當初始化子類的時候,該子類的所有父類都會被初始化。

5)直接使用java.exe命令來運行某個主類。

除了上面幾種方式會自動初始化一個類,其他訪問類的方式都稱不會觸發類的初始化,稱為被動引用。

1、子類引用父類的靜態變數,不會導致子類初始化。

執行結果:

MIGU

用final修飾某個類變數時,它的值在編譯時就已經確定好放入常量池了,所以在訪問該類變數時,等於直接從常量池中獲取,並沒有初始化該類。

初始化的步驟

1、如果該類還沒有載入和連接,則程序先載入該類並連接。

2、如果該類的直接父類沒有載入,則先初始化其直接父類。

3、如果類中有初始化語句,則系統依次執行這些初始化語句。

在第二個步驟中,如果直接父類又有直接父類,則系統會再次重復這三個步驟來初始化這個父類,依次類推,JVM最先初始化的總是java.lang.Object類。當程序主動使用任何一個類時,系統會保證該類以及所有的父類都會被初始化。

⑥ java 編譯通過,運行時,找不到或無法載入主類

樓主的環境變數沒有什麼問題,問題在於
java
hello.java
這一行,原因:
1.java
命令是運行程序的命令,它最終會調用虛擬機載入並執行
java
位元組碼(hello.class文件),所以如果使用
java
hello.java,這樣虛擬機回去載入
hello.java這個源文件,而類載入過程會進行驗證,顯然這種格式是虛擬機無法識別的(虛擬機需要的是位元組碼文件)
2.那為什麼不使用
java
hello.class
呢?因為虛擬機載入位元組碼文件的時候是根據你java
命令後面的字元串(也就是hello.classs),在前面加上包名,後面加上".class",然後再去載入這個位元組碼文件的,也就是說程序會自動在後面加上".class"後綴,所以你不用加,加了反而找不到這個文件了。

⑦ 當java程序有多個類時,具體電腦怎麼編譯操作執行

java類的載入是懶惰式載入
就是用到了就載入,而且只會載入一次
基本流程應該是
運行一個java程序的時候,先執行入口方法main(),然後迭代載入main()方法所在的類的父類
然後用到什麼類就載入什麼類

⑧ java中類的載入是在什麼時候做的

樓上的負責一點好么,類載入是在編譯的時候?載入一個類需要用到載入器,
你程序都沒運行,jvm都沒啟動,哪來的載入器,你拿什麼去載入一個類?
類載入的時候是運行程序時 它就載入了,至於編譯,你用IDE,是你一保存,它就給編譯好了。

⑨ jdk中提供了什麼方法對java類文件進行編譯

importjava.lang.reflect.Method;
importjava.net.URL;
importjava.net.URLClassLoader;

importjavax.tools.JavaCompiler;
importjavax.tools.ToolProvider;

publicclassDemo01{

publicstaticvoidmain(String[]args)throwsException{

JavaCompilercompiler=ToolProvider.getSystemJavaCompiler();

intresult=compiler.run(null,null,null,"C:/source/HelloWorld.java");

System.out.println(result==0?"編譯成功":"編譯失敗");

URL[]urls=newURL[]{newURL("file:/"+"C:/source/")};

URLClassLoaderclassLoader=newURLClassLoader(urls);

Class<?>clazz=classLoader.loadClass("HelloWorld");

//調用main方法
Methodm=clazz.getMethod("main",String[].class);

m.invoke(null,(Object)newString[]{});

}

}

上述代碼會將c盤目錄下的HelloWorld.java文件編譯成HelloWorld.class文件,並將其載入到JVM虛擬機中,調用main方法將其執行

⑩ java程序什麼是類載入

你可以了解一下
深入理解java虛擬機,
java類載入
是因為在運行時當它需要引用某個類的時候,會先去載入這個類,就是去讀這個class文件到內存裡面來,現在還沒有創建這個類的實例,
你可以理解為
你寫的java代碼在編譯成class文件後,並沒有去執行,或者去引用他,只有程序運行時它將要使用這個類的時候才會去讀取這個class文件,這時候叫做類載入,當緩存了這個類文件之後,後面的創建類的時候都會去引用它,因為類載入是運行是載入,所以java代碼在運行時是有辦法修改的,同樣java類載入也允許載入一個遠程的class文件,也代表它是支持程序不停止時更新程序代碼的。

閱讀全文

與java類載入編譯相關的資料

熱點內容
加密媒體怎麼輸密碼 瀏覽:161
方舟如何刪除伺服器數據 瀏覽:600
用閱讀app怎麼看18 瀏覽:689
gn文件編譯 瀏覽:783
酷閃加密系統 瀏覽:820
區塊鏈數據加密 瀏覽:389
3d命令集 瀏覽:289
單片機的智能產品工廠里有 瀏覽:300
事業單位程序員有必要去嗎 瀏覽:583
人工智慧訓練小鳥python 瀏覽:132
怎樣把兩個pdf合並成一個 瀏覽:681
什麼app帶仿製圖章 瀏覽:420
單片機CJNE什麼意思 瀏覽:569
廊坊伺服器是什麼 瀏覽:763
客戶解壓要打欠條還是收據 瀏覽:774
通過app組件啟動有什麼壞處 瀏覽:775
不屬於國產密碼演算法 瀏覽:861
單片機LED顯示字型檔 瀏覽:353
日本文件夾品牌十大名牌 瀏覽:397
靜脈壓縮襪和打底褲的區別 瀏覽:345