aaget( 你的索引 )getClass() 实际上,这个就相当于MainFormListclass
这样就获取到了你所get出来的元素的 泛型类型 了,
大多是反射的时候在需要获取。。。
希望可以帮助到你
获得方法的代码如下,字段的类似
/Project Name [online-courses]
File Name [day02genericGenericDemo5java]
Creation Date [2016-11-23]
<p>
Copyright© 2016 geyyang@hotmailcom All Rights Reserved
<p>
Work hard, play harder, think big and keep fit
/
package day02generic;
import javalangreflectMethod;
import javalangreflectParameterizedType;
import javalangreflectType;
import javautilList;
/
泛型示例-使用反射获取泛型类型<br />
@author <a href="mailto:geyyang@hotmailcom">杨舸</a>
@version 100
@since jdk 18
/
public final class GenericDemo5 {
public void testGenericReflection(List<String> list) {
}
/
测试方法<br />
@param args 命令行参数
@throws Exception 抛出的异常
/
public static void main(String[] args) throws Exception {
Method method = GenericDemo5classgetMethod("testGenericReflection", Listclass);
Type[] parameterTypes = methodgetGenericParameterTypes();
ParameterizedType parameterType = (ParameterizedType) parameterTypes[0]; // 获得第一个泛型参数, Collection类型的集合只有一个泛型参数, Map类型的集合有两个泛型参数
Systemoutprintln(parameterTypegetRawType()); // interface javautilList
Systemoutprintln(parameterTypegetTypeName()); // javautilList<javalangString>
Systemoutprintln(parameterTypegetActualTypeArguments()[0]); // class javalangString
}
}
//泛型并没有想象中那那么强力……
//换句话说就是里面什么都能放
//判断这个列表是什么类型的并没有意义
import javautilArrayList;
import javautilList;
public class Main{
public static void printType(Object object){
if(object instanceof List){
List list=(List)object;//什么都能放
listadd(new Main());
if(!listisEmpty()){
for(Object o:list)
Systemoutprintln(ogetClass()getSimpleName());
//Systemoutprintln("object是List<String>类型");
}else{
Systemoutprintln("object是List,但是不是List<String>类型");
}
}else{
Systemoutprintln("object不是List类型");
}
}
public static void main(String[] args){
List<String> list=new ArrayList<String>();
listadd("haha");
listadd("what");
printType(list);
}
}
在父类的构造方法中,获取泛型的具体类型
import javalangreflectParameterizedType;
import javalangreflectType;
import comopensymphonyxwork2ModelDriven;
/
工具类直接返回ModelDriven的对象
/
public class ModelBaseAction<T> extends BaseAction implements ModelDriven<T> {
protected T model;
/
通过反射,获取泛型的具体类型并实例化这个类型
/
public ModelBaseAction() {
// 获取反射的类型
javalangreflectType cls = supergetClass()getGenericSuperclass();
if (cls instanceof ParameterizedType) {
ParameterizedType pt = (ParameterizedType) cls;
// 获取所有放到泛型里面的类型
Type[] tps = ptgetActualTypeArguments();
Systemerrprintln(tps[0]getTypeName());
try {
// 实例化这个泛型所代表的类对象
model = (T) ClassforName(tps[0]getTypeName())newInstance();
} catch (Exception e) {
throw new RuntimeException("没有默认构造方法", e);
}
}
}
@Override
public final T getModel() {
return model;
}
}
1概述
在引入泛型之前,Java类型分为原始类型、复杂类型,其中复杂类型分为数组和类。java课程发现引入范型后,一个复杂类型
就可以在细分成更多的类型。
例如原先的类型List,现在在细分成List<Object>,List<String>等更多的类型。
注意,现在List<Object>,List<String>是两种不同的类型,
他们之间没有继承关系,即使String继承了Object。
2定义&使用
类型参数的命名风格为:
推荐你用简练的名字作为形式类型参数的名字(如果可能,单个字符)。最好避免小写字母,这使它和其他的普通的形式参数很容易被区分开来。使用T代表类型,无论何时都没有比这更具体的类型来区分它。这经常见于泛型方法。如果有多个类型参数,我们
可能使用字母表中T的临近的字母,比如S。如果一个泛型函数在一个泛型类里面出现,最好避免在方法的类型参数和类的类型参数中使用同样的名字来避免混
淆。对内部类也是同样。
21定义带类型参数的类
在定义带类型参数的类时,在紧跟类命之后的<>内,指定一个或多个类型参数的名字,同时也可以对类型参数的取值范围进行限定,多个类型参数之间用,号分隔。
定义完类型参数后,可以在定义位置之后的类的几乎任意地方(静态块,静态属性,静态方法除外)使用类型参数,就像使用普通的类型一样。
注意,父类定义的类型参数不能被子类继承。
22定义待类型参数方法
在定义带类型参数的方法时,在紧跟可见范围修饰(例如public)之后的<>内,指定一个或多个类型参数的名字,同时也可以对类型参数的取值范围进行限定,多个类型参数之间用,号分隔。定义完类型参数后,可以在定义位置之后的方法的任意地方使用类型参数,就像使用普通的类型一样。
以上就是关于java 如何获得List的泛型类型全部的内容,包括:java 如何获得List的泛型类型、如何获得当前类的字段,方法参数泛型的类型、请问Java怎么取得一个对象的泛型类型等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)