热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【JAVASE】Java泛型实例化

实例化具有无参数构造函数的泛型对象newInstance()methodneedconstructorwithoutparameterClasscomeformClass




实例化具有无参数构造函数的泛型对象

//newInstance() method need constructor without parameter
//Class come form Class.class
public <T> T getNewObject(Class<T> cls) {
T t&#61;null;
try {
t &#61; cls.newInstance();
} catch (InstantiationException|IllegalAccessException e) {
e.printStackTrace();
}
return t;
}

调用

String i &#61;getNewObject(String.class);

这种方法需要泛型类具有一个无参数构造函数


实例化没有无参数构造函数的泛型对象

//newInstance() method need constructor with parameter
public <T> T getNewObject(Constructor<T> cls, double d) {
T t &#61; null;
try {
t &#61; cls.newInstance(d);
} catch (InstantiationException | IllegalAccessException
| IllegalArgumentException | InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return t;
}

调用

con &#61; Float.class.getConstructor(double.class);
Float k &#61;getNewObject(con,10.0);

这种方法先确定使用泛型类的哪一个构造函数&#xff0c;再通过该构造函数newInstance实例出来。

通用的实例泛型对象&#xff08;无需区别是否有无参数构造函数&#xff09;


通过反射动态创建泛型实例

public class BasePresenter<V extends BaseView,M extends BaseModel>{
private M mModel;
public void attach(){
//1、返回表示此 Class 所表示的实体&#xff08;类、接口、基本类型或 void&#xff09;的直接超类的 Type
Type genType &#61; getClass().getGenericSuperclass();
//2、泛型参数
Type[] types &#61; ((ParameterizedType) genType).getActualTypeArguments();
//3、因为BasePresenter 有两个泛型 数组有两个
try {
//
mModel&#61; (M) ((Class)types[1]).newInstance();
//这里需要强转得到的是实体类类路径
// 如果types[1].getClass().newInstance();并不行&#xff0c;得到的是泛型类型
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
public M getModel(){
return mModel;
}
}

getSuperclass和 getGenericSuperclass的区别


  • getSuperclass返回直接继承的父类不包括泛型参数
  • getGenericSuperclass返回直接继承的父类包含泛型参数

getInterfaces 和 getGenericInterface 的区别


  • getInterfaces 返回直接实现的接口&#xff08;不显示泛型参数&#xff09;
  • getGenericInterface 返回直接实现的接口&#xff08;显示泛型参数&#xff09;

封装成工具类

public class ReflectionUtil {
/**
* 通过type获取className
*/

public static String getClassName(Type type){
if(type&#61;&#61;null){
return "";
}
String className &#61; type.toString();
if (className.startsWith("class")){
className&#61;className.substring("class".length());
}
return className;
}
/**
* 获取子类在父类传入的泛型Class类型
* 获取泛型对象的泛型化参数
* &#64;param o
* &#64;return
*/

public static Type getParameterizedTypes(Object o){
Type superclass &#61; o.getClass().getGenericSuperclass();
if(!ParameterizedType.class.isAssignableFrom(superclass.getClass())) {
return null;
}
Type[] types &#61; ((ParameterizedType) superclass).getActualTypeArguments();
return types[0];
}
/**
* 获取实现类的泛型参数
* &#64;param o
* &#64;return
*/

public static Type getInterfaceTypes(Object o){
Type[] genericInterfaces &#61; o.getClass().getGenericInterfaces();
return genericInterfaces[0];
}
/**
*检查对象是否存在默认构造函数
*/

public static boolean hasDefaultConstructor(Class<?> clazz) throws SecurityException {
Class<?>[] empty &#61; {};
try {
clazz.getConstructor(empty);
} catch (NoSuchMethodException e) {
return false;
}
return true;
}
/**
* 通过Type创建对象
*/

public static Object newInstance(Type type)
throws ClassNotFoundException, InstantiationException, IllegalAccessException {
Class<?> clazz &#61; getClass(type);
if (clazz&#61;&#61;null) {
return null;
}
return clazz.newInstance();
}
/**
* 通过Type获取对象class
* &#64;param type
* &#64;return
* &#64;throws ClassNotFoundException
*/

public static Class<?> getClass(Type type)
throws ClassNotFoundException {
String className &#61; getClassName(type);
if (className&#61;&#61;null || className.isEmpty()) {
return null;
}
return Class.forName(className);
}
}






推荐阅读
  • PHP反射API的功能和用途详解
    本文详细介绍了PHP反射API的功能和用途,包括动态获取信息和调用对象方法的功能,以及自动加载插件、生成文档、扩充PHP语言等用途。通过反射API,可以获取类的元数据,创建类的实例,调用方法,传递参数,动态调用类的静态方法等。PHP反射API是一种内建的OOP技术扩展,通过使用Reflection、ReflectionClass和ReflectionMethod等类,可以帮助我们分析其他类、接口、方法、属性和扩展。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • C语言注释工具及快捷键,删除C语言注释工具的实现思路
    本文介绍了C语言中注释的两种方式以及注释的作用,提供了删除C语言注释的工具实现思路,并分享了C语言中注释的快捷键操作方法。 ... [详细]
  • 求数组中字符串的最长公共前缀(Java)
    求数组中字符串的最长公共前缀(牛客网—牛客题霸算法篇—NC55)题目描述给你一个大小为n的字符串数组strs,其中包含n个字符串,编写一个函数来查找字符串数组中的最长公共前缀,返回 ... [详细]
  • oracle11.2.0.4的rac集群,其中一个节点出现故障,集群无法启动,使用crsctlcheckcrs查看集群状况如下:[grid@db2client]$crsctlche ... [详细]
  • 部分转载自:http:blog.csdn.netliujiuxiaoshitouarticledetails69920917头文件#include<assert.h& ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 包含A-Z的字母的消息通过以下规则编码:'A'-1'B'-2'Z'-26给定一个包含数字的编码消息,请确定解 ... [详细]
  • Spring MVC定制用户登录注销实现示例
    这篇文章描述了如何实现对SpringMVCWeb应用程序的自定义用户访问(登录注销)。作为前提,建议读者阅读这篇文章,其中介 ... [详细]
  • Spring 源码阅读 74:事务管理的原理BeanFactoryTransactionAttributeSourceAdvisor 分析
    本文通过对BeanFactoryTransactionAttributeSourceAdvisor类的分析,了解了Spring是如何通过AOP来完成事务的管理的&#x ... [详细]
  • 美国制造工程协会(AmericanSocietyofManufacturingEngineers,ASME)机器视觉分会和美国机器人工业协会(RoboticIndustriesAs ... [详细]
author-avatar
爱智孝的蛋清汤
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有