午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

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

瀏覽:225日期: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
主站蜘蛛池模板: 半推半就一ⅹ99av | 天堂在线视频网站 | 美女久久久久久久 | 国产精品2019 | 日韩中文字幕免费视频 | а√天堂8资源中文在线 | 一区二区三区久久 | 成人免费视频观看 | 亚洲视频欧洲视频 | 亚洲欧美日本在线观看 | 国内免费精品视频 | 国产精品网页 | 日韩中文视频 | 国产丰满美女做爰 | 蜜桃精品噜噜噜成人av | 黄色a免费 | 久久久二区 | 伊人网伊人影院 | 中文字幕视频网 | 日本高清www免费视频 | 国产日韩欧美 | 亚洲色综合| 色99色| 国产精品永久久久久久久久久 | 免费看av在线 | 欧美区亚洲区 | 免费一级片 | 中文字幕亚洲日本 | 啪啪激情网 | 国产中文字幕一区二区三区 | 欧美激情自拍 | 伊人不卡 | 毛片视频网站在线观看 | 激情网五月天 | 亚洲欧美视频在线观看 | 亚洲一区在线免费观看 | 欧美精品久久久久久久久老牛影院 | 最新超碰在线 | 毛片直接看 | 亚洲视频欧美 | 欧洲av一区 |