国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

java - 匿名內部類和繼承類,在實現ClassLoader時為什么會有區別

瀏覽:95日期:2023-11-29 09:52:36

問題描述

最近在看Java虛擬機,類加載器那節舉了這么一個例子:

/***類加載器與instanceof關鍵字演示**@author zzm*/public class ClassLoaderTest{ public static void main(String[]args) throws Exception{ClassLoader myLoader=new ClassLoader(){ @Override public Class<?>loadClass(String name)throws ClassNotFoundException{try{ String fileName=name.substring(name.lastIndexOf('.')+1)+'.class'; InputStream is=getClass().getResourceAsStream(fileName); if(is==null){return super.loadClass(name); } byte[]b=new byte[is.available()]; is.read(b); return defineClass(name,b,0,b.length);}catch(IOException e){ throw new ClassNotFoundException(name);} }};Object obj=myLoader.loadClass('org.fenixsoft.classloading.ClassLoaderTest').newInstance();System.out.println(obj.getClass());System.out.println(obj instanceof org.fenixsoft.classloading.ClassLoaderTest);//false }}

總而言之就是用自定義的類加載器去加載一個類,返回的類與jvm自帶的SystemClassLoader加載的類不同。

那么如果用一個繼承自ClasserLoader的類,按理說也是同樣的效果

package jvm;public class MyClassLoader extends ClassLoader{ @Override public Class<?> loadClass(String fullClassName) throws ClassNotFoundException{try { String fileName = fullClassName.substring(fullClassName.lastIndexOf('.')+1,fullClassName.length())+'.class'; InputStream is = getResourceAsStream(fileName); if(is==null){return super.loadClass(fullClassName); } byte[] bytes = new byte[is.available()]; is.read(bytes); return defineClass(fullClassName,bytes,0,bytes.length);}catch (Exception e){ throw new ClassNotFoundException();} } public static void main(String[] args) throws Exception{ClassLoader myClassLoader = new MyClassLoader();/**ClassLoader myClassLoader = new ClassLoader() { @Override public Class<?> loadClass(String fullClassName) throws ClassNotFoundException {try { String fileName = fullClassName.substring(fullClassName.lastIndexOf('.')+1,fullClassName.length())+'.class'; InputStream is = getClass().getResourceAsStream(fileName); if(is==null){return super.loadClass(fullClassName); } byte[] bytes = new byte[is.available()]; is.read(bytes); return defineClass(fullClassName,bytes,0,bytes.length);}catch (Exception e){ throw new ClassNotFoundException();} }};/**/ClassLoader systemClassLoader = java.lang.ClassLoader.getSystemClassLoader();Class myClass = myClassLoader.loadClass('jvm.MyClassLoader');Class systemClass = systemClassLoader.loadClass('jvm.MyClassLoader');Object myObj = myClass.newInstance();Object systemObj = systemClass.newInstance();System.out.println(myClass.equals(systemClass));//trueSystem.out.println(myObj.getClass().equals(systemObj.getClass()));//true }}

注釋里的代碼就是匿名內部類的繼承,注意到這里myClass和systemClass是完全相等的,但是myClass是使用繼承自ClassLoader的類MyClassLoader生成的,請問這是為什么呢。。。

問題解答

回答1:

第二個代碼走到

if(is==null){ return super.loadClass(fullClassName);}

加載class文件用getClass().getResourceAsStream

標簽: java
主站蜘蛛池模板: 久久在线精品 | 91精品国产一区二区三区四区 | 日韩欧美一级毛片精品6 | 欧美日韩亚洲精品一区 | 国产成人精品一区二区 | 亚洲国产精品久久人人爱 | 亚洲精品国自产拍在线观看 | 99久久精品免费精品国产 | 深夜国产 | 久久精品亚瑟全部免费观看 | 国产欧美日韩免费一区二区 | 夜夜操夜夜爽 | 欧美日韩中文字幕在线观看 | 黄色三级网 | 欧美成人三级大全 | 91精品国产免费久久久久久青草 | 国产在线欧美日韩精品一区二区 | 亚洲加勒比久久88色综合1 | 91九色首页 | 国产免费一区二区三区免费视频 | 国产人成免费视频 | 久久欧美精品 | 999久久久精品视频在线观看 | 国产一区亚洲二区 | 久草视频精品 | 国产中文字幕在线免费观看 | 理论视频在线观看 | 日本aaa毛片 | rion美乳弹出来四虎在线观看 | 在线免费观看国产视频 | 99久久亚洲| 男女一级 | 91寡妇天天综合久久影院 | 欧美成人在线观看 | 99久久综合| 久久综合成人网 | 黄色三级在线 | 精品国产三级a | 亚洲一区二区三区香蕉 | 亚洲欧美日韩精品永久在线 | 免费观看欧美精品成人毛片能看的 |