带有泛型参数的Java抽象类,它实现了自己的泛型参数

时间:2017-03-20 13:45:01

标签: java class generics interface abstract

我面临一个棘手的问题。 我正在尝试创建一个回调管理器泛型类,它接受任何类型接口的泛型。计划是这样做的:

public interface LocationListener {
    void locationChanged();
    void providerChanged();
}

//The implementation declaration below is wrong...
public abstract class CallbackManager<T> implements T {
    //do something
}

public class MyCallbackManager extends CallbackManager<LocationListener> {

   @Override
   public void locationChanged() {

   } 

   @Override
   public void providerChanged() {

   }
}

一般来说,我试图避免像这样构建MyCallbackManager类:

public class MyCallbackManager extends CallbackManager<LocationListener> implements LocationListener {

   @Override
   public void locationChanged() {

   } 

   @Override
   public void providerChanged() {

   }
}

有没有办法实现这一目标? 我期待着你的回复。

修改

因为您要求澄清用例。这就是它背后的想法:

public abstract class CallbackManager<T>  {

    protected interface FunctionalInterface<T> {
        void run(T type);
    }

    protected ArrayList<WeakReference<T>> eventQueue = new ArrayList<>();

    protected void flush(@NonNull FunctionalInterface<T> functionalInterface) {
        for (int i = eventQueue.size() - 1; i >= 0; i--) {
            WeakReference<T> weakReference = eventQueue.get(i);
            T type = weakReference.get();
            if (type == null) {
                unregister(i);
            } else {
                functionalInterface.run(type);
            }
        }
    }
}

public class CallbackManagerLocation extends CallbackManager<LocationListener> implements LocationListener {

   @Override
   public void locationChanged() {
        flush((ll) -> ll.locationChanged());
   } 

   @Override
   public void providerChanged() {
        flush((ll) -> ll.providerChanged());
   }
} 

CallbackManagerLocation中实现的接口仅用于具有与CallbackManager中保存的接口完全相同的命名约定。

2 个答案:

答案 0 :(得分:2)

抱歉,但这是不允许的。由此产生的问题数量将是巨大的。例如,假设您在CallbackManager中有一个函数public T locationChanged()。这将违反接口,而不会在CallbackManager类中显而易见。还有更多这样的例子。

答案 1 :(得分:1)

不,你不能这样做,

public abstract class CallbackManager<T> implements T

它将抛出编译时错误,因为类T没有描述抽象类根据JAVA doc中提供的类加载机制实现的实际引用类型。

还有另一种方法,你可以这样做, public abstract class CallbackManager<ParentListener> implements ParentListener

但您会收到Cannot refer to the type parameter LocationListener as a supertype之类的错误消息 并且在任何情况下都不需要它,如果存在,则可以采用其他方式进行回答