1. 程式人生 > >JVM——直接引用和符號引用

JVM——直接引用和符號引用

在JVM中,類從被載入到虛擬機器記憶體中開始,到卸載出記憶體為止,
它的整個生命週期包括:載入、驗證、準備、解析、初始化、使用和解除安裝7個階段。
而解析階段即是虛擬機器將常量池內的符號引用替換為直接引用的過程。

1.符號引用(Symbolic References):

  • 符號引用以一組符號來描述所引用的目標,符號可以是任何形式的字面量,只要使用時能夠無歧義的定位到目標即可。
  • 例如,在Class檔案中它以CONSTANT_Class_info、CONSTANT_Fieldref_info、CONSTANT_Methodref_info等型別的常量出現。符號引用與虛擬機器的記憶體佈局無關,引用的目標並不一定載入到記憶體中。
  • 在Java中,一個java類將會編譯成一個class檔案。在編譯時,java類並不知道所引用的類的實際地址,因此只能使用符號引用來代替。比如org.simple.People類引用了org.simple.Language類,在編譯時People類並不知道Language類的實際記憶體地址,因此只能使用符號org.simple.Language(假設是這個,當然實際中是由類似於CONSTANT_Class_info的常量來表示的)來表示Language類的地址。
  • 各種虛擬機器實現的記憶體佈局可能有所不同,但是它們能接受的符號引用都是一致的,因為符號引用的字面量形式明確定義在Java虛擬機器規範的Class檔案格式中。

2.直接引用:

 直接引用可以是

  • 直接指向目標的指標(比如,指向“型別”【Class物件】、類變數、類方法的直接引用可能是指向方法區的指標)
  • 相對偏移量(比如,指向例項變數、例項方法的直接引用都是偏移量)
  • 一個能間接定位到目標的控制代碼

直接引用是和虛擬機器的佈局相關的,同一個符號引用在不同的虛擬機器例項上翻譯出來的直接引用一般不會相同。如果有了直接引用,那引用的目標必定已經被載入入記憶體中了。