java获取泛型的类型_Java 获取泛型的类型实例详解

Java 获取泛型的类型实例详解

Java 泛型实际上有很多缺陷,比如不能直接获取泛型的类型,不能获取带泛型类等。

以下方式是不正确的:

①.获取带泛型的类的类型

Class lstUClazz = List.class

②获取局部变量泛型的类型

List listUser = new ArrayList();

Type genType = listUser.getClass().getClass().getGenericSuperclass();

Class templatClazz = null;

if(ParameterizedType.class.isInstance(genType)

{

//无法获取到User类,或者可能获取到错误的类型,如果有同名且不带包名的泛型存在

ParameterizedType parameterizedType = (ParameterizedType) genType;

templatClazz = (Class) parameterizedType.getActualTypeArguments()[0];

}

那么,如何才能获取到泛型的类型

①.必须具有真实类型的存在

②.泛型的类型是明确的如(List是明确的,List是不明确的)

满足以上两点,我们就可以获取泛型的类型了

1.通过继承方式,明确类型,然后获取泛型类

public abstract class JdbcDaoSupport {

protected JdbcDaoSupport() {

}

public Class getTempalteType()

{

Class clazz = (Class) ((ParameterizedType) getClass()

.getGenericSuperclass()).getActualTypeArguments()[0];

return clazz;

}

}

public class UserDao extends JdbcDaoSupport {

}

public class Test{

public static void main(String[] args)

{

UserDao dao = new UserDao();

Class clazz = dao.getTemplateType();

System.out.println(clazz.getName()); //输出 xxx.xxx.User

}

}

2.获取类属性的泛型类型

public class Test extends ClassA {

private List list;

private Map map;

/***

* 获取List中的泛型

*/

public static void testList() throws NoSuchFieldException, SecurityException {

Type t = Test.class.getDeclaredField("list").getGenericType();

if (ParameterizedType.class.isAssignableFrom(t.getClass())) {

for (Type t1 : ((ParameterizedType) t).getActualTypeArguments()) {

System.out.print(t1 + ",");

}

System.out.println();

}

}

/***

* 获取Map中的泛型

*/

public static void testMap() throws NoSuchFieldException, SecurityException {

Type t = Test.class.getDeclaredField("map").getGenericType();

if (ParameterizedType.class.isAssignableFrom(t.getClass())) {

for (Type t1 : ((ParameterizedType) t).getActualTypeArguments()) {

System.out.print(t1 + ",");

}

System.out.println();

}

}

public static void main(String args[]) throws Exception {

System.out.println(">>>>>>>>>>>testList>>>>>>>>>>>");

testList();

System.out.println("<<<<<<<<<<

System.out.println(">>>>>>>>>>>testMap>>>>>>>>>>>");

testMap();

System.out.println("<<<<<<<<<<

System.out.println(">>>>>>>>>>>testClassA>>>>>>>>>>>");

new Test().testClassA();

System.out.println("<<<<<<<<<<

}

}

3.获取局部变量的泛型的类型

List lst = new ArrayList(){};

Type genType = listUser.getClass().getClass().getGenericSuperclass();

Class templatClazz = null;

if(ParameterizedType.class.isInstance(genType)

{

ParameterizedType parameterizedType = (ParameterizedType) genType;

templatClazz = (Class) parameterizedType.getActualTypeArguments()[0];

}

实际上,我们发现,能获取到泛型的类型实际上都是进行了“继承”。当然如果能熟练运用上述技巧,可以做很多事情,比如开源项目Gson中的TypeToken就是利用上述技巧,实现json与复杂类型的转换的。

很多情况下,Class被用来当作参数,我们其实可以将带泛型的类作为参数传入

我们一般为了方便,很少去特定定义一个类,因此,我们需要使用如下方式了。

Class clz = new ArrayList(){}.getClass();

例子

class JsonToObjectUtil {

public static T jsonToObject(Class clz,List jsonList){

Type genType = clz.getClass().getGenericSuperclass();

Class templatClazz = null;

if(ParameterizedType.class.isInstance(genType));

{

ParameterizedType parameterizedType = (ParameterizedType) genType;

templatClazz = (Class) parameterizedType.getActualTypeArguments()[0];

}

List lst = new ArrayList();

/*****/

if(templatClazz!=null && jsonList!=null)

{

for (String str : jsonList) {

Gson gson = new Gson();

Object fromJson = gson.fromJson(str, templatClazz);

lst.add(fromJson);

}

}

/*****/

return (T) lst;

}

public static void main(String[] args) {

List jsonList = null;

//略去一部分填充jsonList的逻辑

Class superClazz = new ArrayList(){}.getClass();

List jsonToObject = JsonToObjectUtil.jsonToObject(superClazz, jsonList);

}

}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值