isAssignableFrom 是用来判断一个类Class1和另一个类Class2是否相同或是另一个类的超类或接口。
通常调用格式是
Class1.isAssignableFrom(Class2)
调用者和参数都是 java.lang.Class 类型。
这个方法在如下情况下返回true
1.class1跟class2是同一类型 则返回true
2.class1是class2的超类或超接口 则返回true
如:Object.class.isAssignableFrom(String.class) Object是String的超类 所以返回true
String.class.isAssignableFrom(String.class) 返回true
而 instanceof 是用来判断一个对象实例是否是一个类或接口的或其子类子接口的实例。 格式是: oo instanceof TypeName 第一个参数是对象实例名,第二个参数是具体的类名或接口名
具体例子如下:
java 代码
- packagetest;
-
-
-
- publicclassTest2{
-
- publicvoidtestIsAssignedFrom1()
- {
- System.out.println(String.class.isAssignableFrom(Object.class));
- }
-
- publicvoidtestIsAssignedFrom2()
- {
- System.out.println(Object.class.isAssignableFrom(Object.class));
- }
-
- publicvoidtestIsAssignedFrom3()
- {
- System.out.println(Object.class.isAssignableFrom(String.class));
- }
-
- publicvoidtestInstanceOf1()
- {
- Stringss="";
- System.out.println(ssinstanceofObject);
- }
-
- publicvoidtestInstanceOf2()
- {
- Objecto=newObject();
- System.out.println(oinstanceofObject);
- }
-
-
- publicstaticvoidmain(String[]args){
- Test2test=newTest2();
- test.testIsAssignedFrom1();
- test.testIsAssignedFrom2();
- test.testIsAssignedFrom3();
- test.testInstanceOf1();
- test.testInstanceOf2();
- }
- }
-
- 打印结果为:
- false
- true
- true
- true
- true
分享到:
相关推荐
System.out.println(A.class.isAssignableFrom(a.getClass())); // true,因为 a 是 A 类型 System.out.println(B.class.isAssignableFrom(b.getClass())); // true,因为 b 是 B 类型 System.out.println(A....
这个方法属于java.lang.Class类,用于判断一个类是否可以被赋值给另一个类或者接口。也就是说,如果A类是B类的父类(或者A接口是B接口的扩展),那么Class对象表示A的`isAssignableFrom`方法调用表示B的Class对象时...
System.out.println(B.class.isAssignableFrom(A.class)); // 输出:false System.out.println(B.class.isAssignableFrom(B.class)); // 输出:true System.out.println(B.class.isAssignableFrom(C.class)); // ...
System.out.println(String.class.isAssignableFrom(Object.class)); // 输出 false System.out.println(Object.class.isAssignableFrom(String.class)); // 输出 true ``` 第一行代码表示`String`类不能被赋予`...
有时我们需要判断某个类是否实现了某个接口...从字面意思可以看出,IsAssignableFrom表示BarClass类型能否赋值给IFoo接口,所以它返回true的条件就是BarClass直接或间接实现了IFoo接口。Type类型中还有一个方法是IsSu
比较类时,应避免依赖类名,而应使用`instanceof`或`Class.isAssignableFrom()`方法,以确保类型安全。 9. **Prevent int promotion with & 0xff**: 当处理字节时,使用`& 0xff`确保不会发生意外的整数提升。这...
1. instanceof关键字 2. isInstance()方法 3. instanceof,isInstance,isAssignableFrom区别是什
通过`Class.forName()`方法或`类名.class`可以获取到Class对象。一旦有了Class对象,就可以获取类的元信息,如类名、包名、父类、接口、修饰符等。 2. **创建对象**: 通过反射,我们可以在运行时动态创建对象。...
结合`URL`和`File`,我们可以遍历JAR文件和目录,查找包含类文件的`.class`资源。 5. **反射**:Java反射API允许我们在运行时检查类、接口、字段和方法的信息。`Class<?> clazz = Class.forName(className);`之后,...
} else if (clazz.isAssignableFrom(Serializable.class)) { return (T) bundle.getSerializable(key); } else { // 其他基本类型 return (T) bundle.getString(key); } } return null; } public void ...
if (String.class.isAssignableFrom(clazz)) { System.out.println("Class is a string-like."); } ``` ### 泛型信息 虽然Java的泛型在编译后会被擦除,但反射仍然提供了一些方式来获取泛型信息,比如`...
if (classObj.isAssignableFrom(InterfaceClass.class)) { // 类实现了接口 } ``` - 获取注解: ```java Annotation annotation = classObj.getAnnotation(MyAnnotation.class); ``` 6. **异常处理** - ...
在 Java 中,每个类都有一个对应的 Class 对象,我们可以通过 getClass() 方法或使用 .class 语法来获取一个类的 Class 对象。 判断一个类是否为基本数据类型可以使用 Class 对象的 isPrimitive() 方法,该方法返回...
if (clazz.isAssignableFrom(MyInterface.class)) { // 类或其父类实现了MyInterface接口 } ``` 在实际应用中,Java反射常用于框架、插件系统、序列化、元数据处理、动态代理和单元测试等领域。JavaBean是反射的一...
* 检查类是否是某个类或接口的实例:`clazz.isAssignableFrom(otherClazz)`。 * 获取类的超类:`clazz.getSuperclass()`。 * 获取接口:`clazz.getInterfaces()`。 * 获取构造器:`clazz.getConstructors()` 和 ...
在Java中,`java.lang.Class`类是反射的核心,它代表了运行时的类信息。通过类的对象,我们可以获取类的名字、构造器、方法、字段等信息。例如,我们可以通过`Class.forName("全限定类名")`来获取一个类的`Class`...
Constructor<Person> constructor = demo.getConstructor(String.class, int.class); Person person = constructor.newInstance("John", 30); ``` 反射还提供了以下功能: 1. 访问和修改字段:`Field`类代表类的...
在Java中,反射机制主要通过java.lang.Class类、java.lang.reflect包中的类(如Constructor、Method、Field)来实现。本文将深入探讨Java反射的基本概念、用途、优缺点以及如何使用。 一、什么是Java反射 Java反射...
接着,通过`Class.newInstance()`方法创建一个新的对象实例,这个新对象与原始对象具有相同的类类型。然后,通过`Field`类获取类的所有字段,遍历这些字段,如果字段是引用类型,我们需要递归地调用深度拷贝方法。...