JAVA虛擬機加載類的方式解析

      虛擬機加載類的途徑 
      1
      、由 new 關鍵字創建一個類的實例 
        
      在由運行時刻用 new 方法載入 
        
      如:Dog dog new Dog(); 
      2
      、調用 Class.forName() 方法 
        
      通過反射加載類型,并創建對象實例 
        
      如:Class clazz Class.forName“Dog”); 
             Object dog
      clazz.newInstance(); 
      3
      、調用某個 ClassLoader 實例的 loadClass() 方法 
        
      通過該 ClassLoader 實例的 loadClass() 方法載入。應用程序可以通過繼承 ClassLoader 實現自己的類裝載器。 
        
      如:Class clazz classLoader.loadClass“Dog”); 
             Object dog
      clazz.newInstance();
      三者的區別: 
      1
      2使用的類加載器是相同的,都是當前類加載器。(即:this.getClass.getClassLoader)。3由用戶指定類加載器。如果需要在當前類路徑以外尋找類,則只能采用第3種方式。第3種方式加載的類與當前類分屬不同的命名空間。另外,1是靜態加載,23是動態加載 
      兩個異常(exception) 
      靜態加載的時候如果在運行環境中找不到要初始化的類,拋出的是NoClassDefFoundError,它在JAVA的異常體系中是一個Error 
      動態加載的時候如果在運行環境中找不到要初始化的類,拋出的是ClassNotFoundException,它在JAVA的異常體系中是一個checked異常 
      Class.forName
      ClassLoader.loadClass區別 
      Class
      的裝載包括3個步驟:加載(loading,連接(link,初始化(initialize
      Class.forName(className)
      實際上是調用Class.forName(className, true, this.getClass().getClassLoader())。第二個參數,是指Classloading后是不是必須被初始化。 
      ClassLoader.loadClass(className)
      實際上調用的是ClassLoader.loadClass(name, false),第二個參數指Class是否被link 
      Class.forName(className)
      裝載的class已經被初始化,而ClassLoader.loadClass(className)裝載的class還沒有被link。一般情況下,這兩個方法效果一樣,都能裝載Class。但如果程序依賴于Class是否被初始化,就必須用Class.forName(name)了。 
      例如,在JDBC編程中,常看到這樣的用法,Class.forName("com.mysql.jdbc.Driver"). 
      如果換成了getClass().getClassLoader().loadClass("com.mysql.jdbc.Driver"),就不行。 
      com.mysql.jdbc.Driver
      的源代碼如下: 
      Java
      代碼

      // Register ourselves with the DriverManager   

      static {   

          try {   

              java.sql.DriverManager.registerDriver(new Driver());   

          } catch (SQLException E) {   

              throw new RuntimeException("Can't register driver!");   

          }   

      }  

      原來,Driverstatic塊中會注冊自己到java.sql.DriverManager。而static塊就是在Class的初始化中被執行。 
      所以這個地方就只能用Class.forName(className) 
      對于相同的類,JVM最多會載入一次。但如果同一個class文件被不同的ClassLoader載入,那么載入后的兩個類是完全不同的。因為已被加載的類由該類的類加載器實例與該類的全路徑名的組合標識。設有 packagename.A Class ,分別被類加載器 CL1 CL2 加載,所以系統中有兩個不同的 java.lang.Class 實例: <CL1, packagename.A> <CL2, packagename.A>
      北大青鳥網上報名
      北大青鳥招生簡章
      主站蜘蛛池模板: 亚洲国产一区视频| 国产精品一区二区久久不卡| 国产精品乱码一区二区三区| 国产精品亚洲一区二区三区久久| 99久久精品日本一区二区免费| 久热国产精品视频一区二区三区| 在线观看国产一区二区三区| 国产精品被窝福利一区| 无码人妻视频一区二区三区| 亚洲狠狠狠一区二区三区| 国产激情一区二区三区小说 | 三级韩国一区久久二区综合| 一区二区三区四区精品| 国产精品特级毛片一区二区三区 | 九九无码人妻一区二区三区| 午夜视频久久久久一区| 午夜影视日本亚洲欧洲精品一区| 国产成人欧美一区二区三区| 高清一区二区三区| 精品一区二区三区无码免费视频| 国模吧一区二区三区精品视频| 国产精品被窝福利一区| 中文字幕一区日韩精品| 久久国产香蕉一区精品| 亚洲国产欧美一区二区三区| 精品少妇一区二区三区在线| 91午夜精品亚洲一区二区三区 | 中文字幕无码不卡一区二区三区 | 亚洲国产综合无码一区| 狠狠综合久久av一区二区| 中文字幕乱码一区二区免费| 日韩免费视频一区| 久久精品一区二区免费看| 国产主播一区二区三区在线观看| 国产成人精品无人区一区| 日韩高清一区二区| 麻豆AV一区二区三区久久| 色视频综合无码一区二区三区| 99精品一区二区三区| 国产精品污WWW一区二区三区| 亚洲AV成人一区二区三区在线看|