ParameterizedType应用,java反射,获取参数化类型的class实例

ParameterizedType是一个接口,这个类可以用来检验泛型是否被参数化

比如:

class Dao<T>
{
	public Dao(){
		
    }
}
上面的这个类,也就是泛型类,当有子类集成它的时候,子类也许会将其参数化,当然也可能不进行参数化

比如我们在这样的子类中:

class SubDao extends Dao<Student>

{

}

这个我们就是在子类集成的时候将Dao<T>这个泛型参数化了

我们在Dao层对数据库进行操作常常需要得到的是实体的class类,也就是上面的Student这个实体类,我们得到其class实例之后就可以利用反射获取到里面的实体类中各种方法和变量,进而我们可以为实体类进行操作

那么如何在Dao层获取到实体类的class实例成为了这一切操作的基础

下面这些方法我们可以获取到class实例,其实应该知道的是当我们在在StudnetDao层来调用Dao类中的方法时候,其实调用的已经被参数化的Dao,也就是这个方法是Dao<Student>中的,因为我们StudnetDao既然要调用Dao层的方法当然要继承Dao层,而且在继承的时候进行参数化,换个方式说:

class Dao<T>
{
	public Dao()
	{
		
	}
	public T get()
	{
		return null;
	}
}
我们要调用上面的get方法,其实我们在StudnetDao里面调用的已经不是上面的Dao<T>中的get方法了,而是

class Dao<Student>
{
	public Dao(){
		
	}
	public Student get()
	{
		
	}
}
这个Dao<Student>里面的get方法,其实这个类我们是看不到的,因为继承关系,所以在我们子类的构造函数执行的时候就会生成这个类,这样我们只需要写一个泛型化的Dao<T>类,在StudnetDao,CourseDao对其实现继承并且参数化,我们的Dao里面的 方法就可以重复的使用了,进而实现了代码的复用。

我们现在就是遇到的问题更加的清晰了,我们现在需要在Dao<Student>类里面,或者是Dao<T>里面获得实体Student的一个class实例,那么我们需要记性判断,判断什么,在子类继承的时候到底有没有进行参数化

如何判断:有这样的一个方法我们可以获取到当前类的父类

也就是我们在子类中执行获取其父类superclass,判断superclass是Dao<T>还是Dao<Student>就可以知道是不是Dao<T>是不是被参数化了

其实这个地方有一个基础的,需要我们注意就是子类在执行自己的构造方法的时候,我们知道也会执行父类的构造方法,那么在执行父类的构造方法的时候,里面的 this表示的是父类还是自己

Type superclass=this.getClass().getGenericSuperClass();

这个我们是放在Dao的构造方法中,但是在子类的构造方法执行的时候,调用super(),这个地方的this是指的子类,也就是StudentDao这个类,这样我们就获得了StudentDao的父类superclass

那么我们并不知道superclass到底是指的Dao<T>还是Dao<Student>,在判断superclass是否被参数化之前,我们有必要说一下Type这个接口 API文档中是这样写道:

"Type 是 Java 编程语言中所有类型的公共高级接口。它们包括原始类型、参数化类型、数组类型、类型变量和基本类型。"

不管怎样,Type是一个接口,表示类型,我们的superclass就是一个类型,

下面我们要岁superclass进行判断:

我们判断用到了另外的一个接口,通过判断superclass是否为这个接口的一个实例,来判断superclass是否被实例化

这个接口是:

ParameterizedType 

如果superclass是该接口的一个实例化对象就表示superclass被参数化了,也就是superclass:Dao<Student>,当然如果不是这个接口的一个实例就表示是没有被参数化,superclass:Dao<T>

我们这样来进行判断:

if(superclass instanceof ParameterizedType)

{

    当Dao<T> 这个泛型类被参数化之后执行。。。。。

}

我们现在已经知道Dao<T>是否被参数化了,现在我们要做的事情就会获取到T,如何获取

在ParameterizedType中有一个方法:GetActualTypeArguments()这个方法的返回值是一个Type的数组

里面存的就是我们的要的T

我们可以这样创建一个参数化类型的变量:

ParameterizedType  parameterizedtype=null;

parameterizedtype=(ParameterizedType)superclass;

Type tys[]=parameterizedtype.getActualTypeArguments();

其实这个地方我们就获得到了T(Student)并且存储到了Type的数组中

if(tys!=null && tys.length>0)

{

    clazz=(Class)type[0];

}

这样我们就获取到了T的类型,并且得到得到了一个class实例,我们下面就可以利用反射获取到里面的方法和属性并操作

,具体代码如下:

public class Dao<T> {
    private static PreparedStatement st = null;
    public Class clazz;
    public Dao() {
		Type superclass = getClass().getGenericSuperclass();
		ParameterizedType parameterizedType = null;
		if (superclass instanceof ParameterizedType) {
			parameterizedType = (ParameterizedType) superclass;
			Type[] typeArray = parameterizedType.getActualTypeArguments();
			if (typeArray != null && typeArray.length > 0) {
			      clazz=(Class)typeArray[0];
		
			}
		}
	}
}
希望对你有所帮助!




  • 23
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: ParameterizedTypeJava 中的一个接口,它表示一个带有类型参数的类型。它可以用来描述复杂的泛型类型,如 List<String> 等。 ParameterizedType 接口有三个方法,分别返回泛型类型的原始类型(raw type)、参数类型(actual type arguments)和所属的类型(owner type)。在 Java 中,我们经常会使用 ParameterizedType获取泛型类型的信息,比如反射中的 TypeToken,或者 Json 解析库中的 TypeAdapter。 ### 回答2: ParameterizedTypeJava 中的一个接口,用于表示带有参数化类型,也就是泛型类型。 在 Java 中,我们可以定义泛型类或泛型方法,在定义的时候可以使用类型参数(type parameter),这些类型参数可以是具体的类型,也可以是泛型类型。例如,我们可以定义一个泛型类List<T>来表示一个列表,其中的类型参数T可以是具体的类型,比如Integer或String,也可以是另一个泛型类型,比如List<Integer>。当我们实例化一个泛型类的对象时,可以指定具体的类型参数,比如List<Integer> list = new ArrayList<>()。 而ParameterizedType 就是用来表示带有参数化类型的,在 Java 中,它是一个接口,继承自Type接口。ParameterizedType接口提供了一些方法来获取泛型类型的相关信息,比如获取原始类型(raw type)、获取所有的实际类型参数(actual type arguments)等。 通常情况下,当我们通过反射获取一个泛型类型时,得到的是一个ParameterizedType实例。通过ParameterizedType接口提供的方法,我们可以获取到该泛型类型的原始类型、实际类型参数等信息。比如,如果我们获取到了一个泛型类List<Integer>的Type类型,我们可以通过判断该Type是否是ParameterizedType类型,然后再通过ParameterizedType接口提供的方法来获取到List的原始类型(即List.class)和类型参数(即Integer.class)。 总之,ParameterizedType 是用来表示带有参数化类型的接口,在Java中,泛型类或泛型方法的参数是使用类型参数来定义的,而ParameterizedType接口则是用来表示这些泛型类型的。通过ParameterizedType接口提供的方法,我们可以获取泛型类型的原始类型类型参数等相关信息。 ### 回答3: ParameterizedTypeJava语言中的一个接口,用于表示参数化类型,也就是带有泛型类型。在Java中,使用泛型可以让我们编写更加通用、可复用的代码,因此ParameterizedType的作用就是表示这种带有泛型参数的类型ParameterizedType接口是Type的子接口,它有三个方法: - Type[] getActualTypeArguments():获取参数化类型的实际参数类型,返回一个Type数组。 - Type getRawType():获取参数化类型的原始类型,返回一个Class对象。 - Type getOwnerType():获取参数化类型的拥有者类型,如果该类型是一个嵌套类型,则返回其直接宿主。 举个例子来说,假设我们有一个ArrayList,这个List中的元素是String类型。那么这个ArrayList的类型就可以表示为ParameterizedType,其中getRawType()方法会返回ArrayList的原始类型,即Class对象;getActualTypeArguments()方法会返回长度为1的Type数组,数组中唯一的元素就是String类型;getOwnerType()方法返回null,因为ArrayList没有拥有者类型。 通过ParameterizedType,我们可以在运行时获取参数化类型的具体信息,这对于编写一些通用的代码非常有用。例如,我们可以通过反射获取泛型类的实际参数类型,并根据这些类型进行相应的处理。 总之,ParameterizedTypeJava语言中用于表示带有泛型参数的类型的接口,它提供了获取实际参数类型、原始类型以及拥有者类型的方法。通过ParameterizedType,我们可以在运行时获取参数化类型的具体信息,从而编写更加通用、可复用的代码。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值