3

我有一个参数化接口 RestHandler。

public interface RestHandler<T> {
   blah blah blah...
}

我需要使用 Class.forName 从配置创建一个类。现在我想出了三个版本,全部编译成功。

版本 1:

@SuppressWarnings("unchecked")
public static <T> RestHandler<T> create(final String handlerImplFqcn) throws ClassNotFoundException, 
                                                                    IllegalAccessException, 
                                                                    InstantiationException {
    Class<?> handlerClass = Class.forName(handlerImplFqcn);
    return (RestHandler<T>) handlerClass.newInstance();
}

版本 2:

public static RestHandler<?> create(final String handlerImplFqcn) throws ClassNotFoundException, 
                                                                    IllegalAccessException, 
                                                                    InstantiationException {
    @SuppressWarnings("rawtypes")
    Class handlerClass = Class.forName(handlerImplFqcn);
    return (RestHandler<?>) handlerClass.newInstance();
}

版本 3:

public static RestHandler<?> create(final String handlerImplFqcn) throws ClassNotFoundException, 
                                                                    IllegalAccessException, 
                                                                    InstantiationException {
    Class<?> handlerClass = Class.forName(handlerImplFqcn);
    return (RestHandler<?>) handlerClass.newInstance();
}

我的问题是,为什么它们都有效,哪一个是最佳实践?

4

2 回答 2

2

版本 1,重写为:

public static <T extends RestHandler<?>> RestHandler<T> create(final String handlerImplFqcn) throws ClassNotFoundException, IllegalAccessException, InstantiationException, ClassCastException {
    Class<T> handlerClass = (Class<T>) Class.forName(handlerImplFqcn);
    return (RestHandler<T>) handlerClass.newInstance();
}
于 2015-02-04T11:09:36.730 回答
0

使用版本 1。

版本 2 使用原始类型 - 尽可能避免使用这些类型。

版本 3 使用<?>这通常也是一种反模式,因为它很少实现您想要实现的目标。

于 2015-02-04T11:06:03.063 回答