日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

JVM - 实现自定义的ClassLoader就是这么简单

發布時間:2025/3/21 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JVM - 实现自定义的ClassLoader就是这么简单 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Java面試Offer直通車

文章目錄

  • Pre
  • 自定義類加載器
  • 演示
    • Step1 : 復制一個Boss1 的類,編譯后,取到Boss1.class 備用
    • Step2 : 刪除Boss1類
    • Step3 : 編寫自定義ClassLoader
    • Step 4: 自定義目錄存放Boss1.class
    • Step 5 : 運行結果
  • 注意事項

Pre

JVM-白話聊一聊JVM類加載和雙親委派機制源碼解析


自定義類加載器

我們了解了雙親委派機制后,那自定義類加載器相對就很容易了 , 只需要繼承 java.lang.ClassLoader 類 ,重寫findClass方法即可

該類有兩個核心方法:

  • 一個是loadClass(String, boolean),實現了雙親委派機制 .

  • 一個方法是findClass,默認實現是空方法

所以自定義類加載器主要是重寫findClass方法


演示


Step1 : 復制一個Boss1 的類,編譯后,取到Boss1.class 備用


Step2 : 刪除Boss1類


Step3 : 編寫自定義ClassLoader

抽象類CLassLoader ,我們自定義的ClassLoader只需要繼承抽象類ClassLoader,重寫loadClass方法

package com.gof.facadePattern;import java.io.FileInputStream; import java.lang.reflect.Method;/*** @author 小工匠* @version v1.0* @create 2020-06-11 23:09* @motto show me the code ,change the word* @blog https://artisan.blog.csdn.net/* @description**/public class MyClassLoaderTest {static class MyClassLoader extends ClassLoader {private String classPath;public MyClassLoader(String classPath) {this.classPath = classPath;}private byte[] loadByte(String name) throws Exception {name = name.replaceAll("\\.", "/");FileInputStream fis = new FileInputStream(classPath + "/" + name+ ".class");int len = fis.available();byte[] data = new byte[len];fis.read(data);fis.close();return data;}@Overrideprotected Class<?> findClass(String name) throws ClassNotFoundException {try {byte[] data = loadByte(name);//defineClass將一個字節數組轉為Class對象,這個字節數組是class文件讀取后最終的字節數組。return defineClass(name, data, 0, data.length);} catch (Exception e) {e.printStackTrace();throw new ClassNotFoundException();}}}public static void main(String args[]) throws Exception {//初始化自定義類加載器,會先初始化父類ClassLoader,其中會把自定義類加載器的父加載器設置為應用程序類加載器AppClassLoaderMyClassLoader classLoader = new MyClassLoader("D:/artisan");//D盤創建 artisan/com/gof/facadePattern 目錄,將Boss類的復制類Boss1.class丟入該目錄Class clazz = classLoader.loadClass("com.gof.facadePattern.Boss1");Object obj = clazz.newInstance();// 調用sout方法Method method = clazz.getDeclaredMethod("sout", null);method.invoke(obj, null);System.out.println(clazz.getClassLoader().getClass().getName());} }

defineClass 復用ClassLoader的即可 ,主要功能是將一個字節數組轉為Class對象

自定義類加載器的父加載器是AppClassLoader , 但并不是說自定義ClassLoader的父類是AppClassLoader,這一點一定不要搞錯了。


Step 4: 自定義目錄存放Boss1.class


Step 5 : 運行結果


注意事項

Boss1 生成class后,需要把Boss1 刪掉,不然雙親委派(我們并沒有重寫loadClass方法),它又從AppClassLoader加載了 。 需要確保你自定義加載的Boss1 在其父加載器中都不存在。

總結

以上是生活随笔為你收集整理的JVM - 实现自定义的ClassLoader就是这么简单的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。