av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

瀏覽:105日期: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影视| 黄网站免费在线观看 | 我想看一级黄色毛片 | 久久久久久久电影 | 亚洲欧美日韩精品久久亚洲区 | 成人性视频在线播放 | 欧美一级片在线看 | 天堂一区二区三区 | 久久国产精品一区 | 99精品视频在线 | 国产精品国产 | 在线中文字幕第一页 | 特黄av| 精品一级 | 午夜电影日韩 | 中文字幕av在线 | 99久久婷婷国产综合精品 | 精品国产黄色片 | www.9191 | 精品久久不卡 | 成人av免费 | 人人干人人艹 | 中文字幕在线一区二区三区 | 日本视频免费 | 成人免费观看视频 | 一区二区在线 | 亚洲一区二区在线播放 | 日韩中文字幕区 | 毛片在线视频 | 中文字幕国产 | 午夜伊人 | 超碰在线人人 | 亚洲精品乱码久久久久久9色 | 国产专区免费 | 国产黄色一级电影 | 成人小视频在线 |