您可以在运行时检查实际类型参数,但您只能通过反射 API 从字段、方法、构造函数等中读取。示例如下:
import java.lang.reflect.Field;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.List;
public class TypesSample {
public List<String> sampleList;
public static void main(String[] args) throws Exception {
Field f = TypesSample.class.getField("sampleList");
ParameterizedType paramType = (ParameterizedType)f.getGenericType();
Type typeArgument = paramType.getActualTypeArguments()[0];
System.out.println(paramType.toString() + " with argument : " + typeArgument.toString());
}
}
它说 :java.util.List<java.lang.String> with argument : class java.lang.String
由于类型擦除,您不会从对象引用中获取实际参数类型。
//编辑:
这是您可以针对您的情况做的事情:
abstract class GenericDAO<T> {
public void add(Collection<T> many) {
Type typeArg = ((ParameterizedType)this.getClass().getGenericSuperclass()).getActualTypeArguments()[0];
System.out.println("This is a DAO for " + typeArg);
}
}
// create DAOs that define what type parameter is
class IntegerDAO extends GenericDAO<Integer> {}
class StringDAO extends GenericDAO<String> {}
接着 :
GenericDAO<Integer> integerDAO = new IntegerDAO();
integerDAO.add(Arrays.asList(1,2,3));
GenericDAO<String> stringDAO = new StringDAO();
stringDAO.add(Arrays.asList("A","B","C"));
说:这是类 java.lang.Integer 的 DAO 这是类 java.lang.String 的 DAO
但是您需要T
通过扩展泛型类来明确声明什么是。