4

有两个类 X 和 Y 实现了 Base 接口 有一个接口负责处理每种类型的对象

interface Base {
}
class X implements Base {
}
class Y implements Base {
}

interface XProcessor {
    void process(X object);
}
interface YProcessor {
    void process(Y object);
}

但是这种方法的缺点是我必须为每种类型的对象(X,y..)公开一个接口,如果有很多这样的对象,我最终会暴露太多接口。我想我会通过只公开一个接口来处理这个问题,该接口负责处理 Base 类型的对象

interface Processor<E extends Base> {
  void process(E object);
}

实现者编写自己的实现来处理 X 类型的对象

class XProcessor implements Processor<X> {
    void process(X object) {
        //do something
    }
}

这种方法的问题是当我必须在运行时调用方法进程时,我不知道我应该将哪种类型的对象传递给处理器,因为在运行时我无法确定该处理器的类型

void process(Processor p) {
    p.process(??);
}

有没有更好的方法来处理这个问题?

4

3 回答 3

2

正如@tredontho 所建议的,可以使用如下所示的工厂“ProcessorFactory”来获取相关实例,然后调用 process 方法

public class ProcessTest {

    <T extends Base> void processBase(T base) {
        ProcessorFactory.getProcessor(base).process(base);
    }

}


interface Base{
}
class X implements Base{
}
class Y implements Base{
}

interface Processor<E extends Base>{
    void process(E object);
}

interface XProcessor extends Processor<X> {

}
interface YProcessor extends Processor<Y> {

}

class ProcessorFactory {

    @SuppressWarnings("unchecked")
    static <T extends Base> Processor<T> getProcessor(T base) {
        if (base instanceof X) {
            return (Processor<T>) new XProcessorImpl();
        }
        return null;
    }

}

class XProcessorImpl implements XProcessor {

    @Override
    public void process(X object) {
        // TODO Auto-generated method stub

    }

}
于 2013-10-08T14:59:35.407 回答
1

这与运行时无关。如果您编写类似的内容,您已经在编译时删除了该类型

void process(Processor p){
  p.process(??);
}

如果您的Processor接口是通用的,则不应再使用原始类型:

<E extends Base> void process(Processor<E> p){
  p.process(…instance of E…);
}

例如:

<E extends Base> void processAll(Processor<E> p, Collection<? extends E> c){
  for(E item: c) p.process(c);
}
于 2013-10-08T14:56:23.027 回答
1

process()方法必须有参数吗?

你可以走下面的路吗?

每个单独的类都实现processor了包含void process()方法存根的通用接口,从而创建了它们的自定义操作。然后您可以upcast将对象添加到接口中(如果需要,将它们放入某种集合中)。

你可以有类似的东西:

List<Processor> p = new ArrayList<>();
p.add(new Xprocessor);
p.add(new Yprocessor);

for each(Processor pr: p) {
   pr.Processor();
}

多态性将负责其余的工作。

在这种情况下,您甚至不需要泛型。

于 2013-10-08T15:06:59.330 回答