Java获取泛型T的类型 T.class

直接上代码:

public interface CrudRepository<T> {

    Iterable<T> findAll();

}
public class BaseImpl <T> implements CrudRepository<T> {

    @Override
    public Iterable<T> findAll() {
        Class<T> c = getTClass();
        System.out.println(c);
        common(c);
        return null;
    }


    /**
     * 通用的方法使用泛型的class去干一些事情。
     *
     * @param c 泛型类
     */
    private void common(Class<T> c) {

    }

    /**
     * 获取 T.class
     */
    public Class<T> getTClass() {
        return (Class<T>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
    }
}
public class PhoneRepository extends BaseImpl<Phone> {


    public static class Phone {
        private static final long serialVersionUID = 1L;
        private String name;
        private Long price;
        private Long updateDate;

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public Long getPrice() {
            return price;
        }

        public void setPrice(Long price) {
            this.price = price;
        }

        public Long getUpdateDate() {
            return updateDate;
        }

        public void setUpdateDate(Long updateDate) {
            this.updateDate = updateDate;
        }
    }
}
public class Test {

    public static void main(String[] args) {
        PhoneRepository phoneRepository = new PhoneRepository();
        Iterable<Phone> phones = phoneRepository.findAll();
    }
}

结果:
class cn.zero.reflect.PhoneRepository$Phone



工具类:

public class GenericsUtils {

    /**
     * 通过反射,获得定义Class时声明的父类的范型参数的类型.
     *
     * 如public BookManager extends Manager<Book>
     */
    public static Class getSuperClassGenericType(Class clazz) {
        return getSuperClassGenericType(clazz, 0);
    }

    /**
     * 通过反射,获得定义Class时声明的父类的范型参数的类型.
     *
     * 如public BookManager extends Manager<Book>, 返回Book
     */
    public static Class getSuperClassGenericType(Class clazz, int index) throws IndexOutOfBoundsException {
        Type genType = clazz.getGenericSuperclass();
        if (!(genType instanceof ParameterizedType)) {
            return Object.class;
        }
        Type[] params = ((ParameterizedType) genType).getActualTypeArguments();
        if (index >= params.length || index < 0) {
            return Object.class;
        }
        if (!(params[index] instanceof Class)) {
            return Object.class;
        }
        return (Class) params[index];
    }
}
Java中,使用的方法可以通过参数来传入类型。如果您希望获取一个类型的对象(例如一个类或接口的Class对象),可以使用通配符类型参数来达到这个目的。具体步骤如下: 1. 创建一个带有参数的方法,并在方法内部声明一个变量作为类型参数的类型,例如使用类型参数T来代替实际的类型。 ```java public static <T> Class<T> getClass(T obj) { return obj.getClass(); } ``` 在这个方法中,我们将一个对象obj作为方法的参数,并将其转换为Class对象。 2. 在调用该方法时,您需要传递一个具有实际类型的对象作为参数。例如,如果您有一个集合List<String>,您可以调用该方法并传入一个String对象作为参数。 ```java List<String> list = new ArrayList<>(); Class<String> stringClass = getClass(list.get(0)); ``` 在这个例子中,我们获取了列表中的第一个元素(类型为String),并将其传递给方法以获取Class对象。 另外,需要注意的是,由于通配符类型参数是在编译时使用的,因此如果您传递了一个没有在代码中明确指定的类型的对象给方法,那么该方法可能会编译失败或返回错误的Class对象。因此,在调用该方法时需要确保传递的对象是正确的类型。 如果您想要获取一个对象的Class对象并且不关心它的具体类型,那么可以使用通配符类型参数并直接返回该对象的Class对象。例如: ```java public static Class<?> getClass(Object obj) { return obj.getClass(); } ``` 在这个例子中,我们使用了Type变量的别名而不是类型参数T。请注意,这个方法可能会返回任何对象的Class对象,而不仅仅是对象的Class对象。如果您只关心类型Class对象,那么最好使用上面的示例中的示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值