public <U> Class<? extends U> asSubclass(Class<U> clazz)
这是java.lang.Class中的一个方法,作用是将调用这个方法的class对象转换成由clazz参数所表示的class对象的某个子类。举例来说,
List<String> strList = new ArrayList<String>(); Class<? extends List> strList_cast = strList.getClass().asSubclass(List.class);
上面的代码将strList.getClass()获取的class对象转换成Class<? extends List>,这么做似乎没有什么意义,因为我们很清楚strList.getClass()获取的class对象就是ArrayList,它当然是List.class的一个子类;
但有些情况下,我们并不能确知一个class对象的类型,典型的情况是Class.forName()获取的class对象:
Class.forName()的返回类型是Class<?>,但这显然太宽泛了,假设我们需要List.class类型的class对象,但我们传递给Class.forName的参数是未知的(可能是"java.lang.String",也可能是"java.util.ArrayList"),这时我们就可以用到asSubclass()这个方法了,如下:
Class.forName("xxx.xxx.xxx").asSubclass(List.class).newInstance();
当xxx.xxx.xxx是List的子类时,正常执行,当不是List的子类时,抛出ClassCastException,这时我们可以做些别的处理;
如果我们查看Class.asSubclass()在JDK中的中的引用的话,会发现这种用法有很多。
这里有必要说下 instanceof 关键字.
<<object reference>> instanceof <<class/interface name>>
它的用法用于判断一个Object是否是某个超类或者接口的一个子类或者实现类(不一定是直接超类或者直接接口),如下
interface IFace { } class IFaceImpl implements IFace { } class IFaceImplExt extends IFaceImpl { } System.out.println(new IFaceImpl() instanceof IFace); // true System.out.println(new IFaceImplExt() instanceof IFace); // true
asSubclass用于窄化未知的Class类型的范围,而instanceof用于判断一个对象引用是否是一个超类或者接口的子类/实现类,如果试图将instanceof用于Class类型的判断会引起编译错误。
// both will cause compliration error System.out.println(IFaceImpl.class instanceof IFace); System.out.println(IFaceImplExt.class instanceof IFace.class);
相关推荐
3. 类的`.class`语法:`String.class` 或 `Integer.TYPE`(对于基本类型) 4. `Class<?> clazz = Class.forName("全限定类名").asSubclass(subClassType)`:如果需要确保加载的类是某个父类或接口的子类,可以使用...
Class<String> stringClass = clazz.asSubClass(String.class); // 创建新的实例 Object obj = clazz.newInstance(); } catch (ClassNotFoundException | IllegalAccessException | InstantiationException e)...
return Class.forName(className).asSubclass(Fragment.class).newInstance(); } catch (Exception e) { throw new RuntimeException("Error creating fragment", e); } } } // 在Activity中注册 ...
* asSubclass(Class<U> clazz):把传递的类的对象转换成代表其子类的对象 * cast():把对象转换成代表类或是接口的对象 * getClassLoader():获得类的加载器 * getClasses():返回一个数组,数组中包含该类中所有...
1. **通过`.class`语法**:可以直接通过类名的`.class`后缀获取该类的`Class`对象。例如:`String.class`。 - 这种方式适用于已知类的情况。 - 不会触发类的初始化。 2. **通过`forName()`方法**:可以通过`Class...
return WritableComparator.get(getMapOutputKeyClass().asSubclass(WritableComparable.class), this); } ``` 在上面的代码中,我们可以看到,如果用户自定义了比较器,那么就会实例化用户自定义的比较器。如果...
Class<? extends A> subClass = clazz.asSubclass(A.class); ``` 5. **安全性与性能** 尽管反射提供了极大的灵活性,但同时也带来了潜在的安全风险,因为它允许代码绕过常规的访问控制。此外,反射操作通常比...
Java反射的核心在于`java.lang.Class`类,它代表了类的信息,通过反射可以获取到类的所有属性、方法、构造器等。例如,以下代码展示了如何使用反射判断一个对象所属的类: ```java A a = new A(); if (a.getClass()...
你可以通过`Class.forName()`方法或者类的`.class`属性获取到`Class`对象。有了`Class`对象,你就可以获取类的信息,如类名、包名、父类、接口、字段和方法等。 2. `Field`: 表示类的成员变量。通过`Class`对象的`...
* asSubclass()方法:将类转换为子类 * cast()方法:将对象转换为指定类 * forName()方法:返回指定类的Class对象 * getConstructor()方法:返回指定构造方法 * getDeclaredConstructor()方法:返回指定声明的构造...