package com.jaychang.demo; public class Dog { public String say(String name) { System.out.println("Hello " + name); return "Hello " + name; } }
package com.jaychang.demo;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
public class ClassLoaderTest {
static class MyClassLoader extends ClassLoader {
public Class<?> getClass(byte[] byteArray, int off, int len) {
return super.defineClass(byteArray, off, len);
}
}
public static void main(String[] args) {
MyClassLoader myClassLoader = new MyClassLoader();
File classFile = new File(
"F:/Workspace/classloader-demo/target/classes/com/jaychang/demo/Dog.class");
ByteArrayOutputStream baos = null;
BufferedOutputStream bos = null;
FileInputStream fis = null;
BufferedInputStream bis = null;
try {
fis = new FileInputStream(classFile);
baos = new ByteArrayOutputStream();
bis = new BufferedInputStream(fis);
bos = new BufferedOutputStream(baos);
byte[] buff = new byte[1024];
int len = -1;
while ((len = bis.read(buff, 0, 1024)) != -1) {
bos.write(buff, 0, len);
}
bos.flush();
byte[] byteArray = baos.toByteArray();
Class clazz1 = myClassLoader.getClass(byteArray, 0,
byteArray.length);
Class clazz2 = Class.forName("com.haipicheng.dubbo_demo.Dog");
Class clazz3 = Dog.class;
System.out.println("clazz1类装载器为" + clazz1.getClassLoader()
+ ",clazz2类装载器为" + clazz2.getClassLoader() + ",clazz3类装载器为"
+ clazz3.getClassLoader());
System.out.println("clazz1 == clazz2 ?" + (clazz1 == clazz2));
System.out.println("clazz2 == clazz3 ?" + (clazz2 == clazz3));
System.out.println("clazz1 == clazz3 ?" + (clazz1 == clazz3));
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (null != fis) {
try {
fis.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (null != bis) {
try {
bis.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (null != baos) {
try {
baos.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (null != bos) {
try {
bos.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
com.jaychang.demo.Dog,com.jaychang.demo.Dog,com.jaychang.demo.Dog
clazz1类装载器为com.jaychang.demo.ClassLoaderTest$MyClassLoader@97d01f,clazz2类装载器为sun.misc.Launcher$AppClassLoader@472d48,clazz3类装载器为sun.misc.Launcher$AppClassLoader@472d48
clazz1 == clazz2 ?false
clazz2 == clazz3 ?true
clazz1 == clazz3 ?false
说明不同类装载器加载生成的Class对象,尽管调用getName得到的全限定名称是一一样的,但是他们是不同类装载器装载的,由Class对象生成对应的实例就不能相互转换,就会报ClassCastException了
相关推荐
这通常发生在不同类装载器装载的类试图相互访问对方的私有成员时。 #### 五、结论 通过对JBoss JMX实现架构和类装载器机制的深入分析,我们可以更好地理解JBoss是如何管理和监控其内部资源和服务的。正确理解和...
在Java编程语言中,对象类型和相互转化是核心概念,特别是在面向对象编程中。本课主要探讨了如何创建和操作不同类型的对象,以及如何在不同类型之间进行转换。下面将详细阐述这些关键知识点。 1. **对象类型**: ...
在JVM中,每个类都有一个唯一的标识,由其完全限定类名(包括包名和类名)以及加载它的类加载器实例决定。这意味着,即使两个类具有相同的完全限定名,如果由不同的类加载器加载,它们也会被视为不同的类,无法相互...
- **类装载器委派模型**:在典型的类装载过程中,每个类装载器实例都关联有一个父类装载器。当需要查找类或资源时,通常会先委托给父类装载器进行查找,只有当父类装载器找不到时,才会由当前类装载器继续查找。Java...
判断“同一个类”通常基于完全限定类名(包括包名和类名),但在JVM内部,类的唯一标识还包括加载它的类加载器实例。这意味着,即使完全相同的类名,如果由不同的类加载器加载,也会被视为不同的类,无法相互兼容。 ...
然而,当WebLogic在处理CLOB对象时,如果数据源配置不当或者代码处理方式有误,就可能出现ClassCastException。 首先,我们需要了解ClassCastException的原因。这个异常通常发生在试图将一个对象强制转换为不兼容...
例如,在不同的`URLClassLoader`装载相同的JAR文件时,尽管从字节码角度看这些类是相同的,但由于它们被不同的类装载器装载,因此被视为不同的类型。这可能导致`ClassCastException`异常。 ### 总结 通过对JBoss ...
实例38 强制类型转换异常(ClassCastException) 56 实例39 索引越界异常(IndexOutOfBoundsException) 57 实例40 空指针异常(NullPointerException) 58 实例41 数字格式转换异常(NumberFornatException) 59 ...
每个 `.class` 文件都会被特定的类加载器实例加载到 JVM 中,并形成对应的 `Class` 对象。不同类加载器加载同一个类的 `.class` 文件时,这些类虽然名称相同但被认为是不同的类型。这意味着即使两个类具有相同的完全...
在Java编程中,`java.lang.ClassCastException`是一个运行时异常,通常发生在强制类型转换时,如果尝试将一个对象转换为其非兼容类型时就会抛出。这个异常表明在编译时可能成功的类型转换,在运行时被证明是错误的。...
在Java编程中,`final`修饰符和类型转化是两个重要的概念,它们分别涉及类的继承限制和对象的类型转换。 1. `final`修饰符: - `final`类:当一个类被声明为`final`时,它无法被其他类继承。这通常用于防止他人...
根据内部类的定义位置不同,我们可以将其分为成员内部类(Member Inner Class)和局部内部类(Local Inner Class)。 #### 成员内部类 成员内部类是定义在外部类成员位置上的内部类。它可以被声明为`public`、`...
然而,在实现ListView时,我们可能会遇到一个问题,即加载不同布局导致的`ClassCastException`异常。这个异常通常出现在尝试将一个对象强制转换为非兼容类型时,对于ListView,可能是由于在适配器中错误地处理了视图...
即使两个类具有相同的名字和包名,但如果它们是由不同的类加载器加载的,那么这两个类就被认为是不同的。例如,两个类 `C1` 和 `C2` 都来自同一个包 `Pg`,但分别由类加载器 `kl1` 和 `kl2` 加载,那么在 JVM 中,...
这是因为XMLBeans根据XSD文件生成的Java类可能没有足够的信息来区分来自不同XSD但具有相同元素名称的元素。因此,当我们尝试将一个对象强制转换为另一个对象时,如果没有正确地进行类型检查,就会抛出`...
实例38 强制类型转换异常(ClassCastException) 56 实例39 索引越界异常(IndexOutOfBoundsException) 57 实例40 空指针异常(NullPointerException) 58 实例41 数字格式转换异常...
实例38 强制类型转换异常(ClassCastException) 56 实例39 索引越界异常(IndexOutOfBoundsException) 57 实例40 空指针异常(NullPointerException) 58 实例41 数字格式转换异常(NumberFornatException) 59 ...
实例38 强制类型转换异常(ClassCastException) 56 实例39 索引越界异常(IndexOutOfBoundsException) 57 实例40 空指针异常(NullPointerException) 58 实例41 数字格式转换异常...
6. 类与对象:类是创建对象的模板,而对象是类的实例。每个类可以创建多个对象,每个对象都有自己的内存空间,可以拥有独立的数据和行为。 7. 继承与接口的使用场景:继承适合表示"is-a"关系,例如“汽车是一个交通...