这是一个关于管道实现的设计问题。以下是我天真的实现。
管道中各个步骤/阶段的接口:
public interface Step<T, U> {
public U execute(T input);
}
管道中步骤/阶段的具体实现:
public class StepOne implements Step<Integer, Integer> {
@Override
public Integer execute(Integer input) {
return input + 100;
}
}
public class StepTwo implements Step<Integer, Integer> {
@Override
public Integer execute(Integer input) {
return input + 500;
}
}
public class StepThree implements Step<Integer, String> {
@Override
public String execute(Integer input) {
return "The final amount is " + input;
}
}
管道类将保存/注册管道中的步骤并一个接一个地执行它们:
public class Pipeline {
private List<Step> pipelineSteps = new ArrayList<>();
private Object firstStepInput = 100;
public void addStep(Step step) {
pipelineSteps.add(step);
}
public void execute() {
for (Step step : pipelineSteps) {
Object out = step.execute(firstStepInput);
firstStepInput = out;
}
}
}
执行管道的驱动程序:
public class Main {
public static void main(String[] args) {
Pipeline pipeline = new Pipeline();
pipeline.addStep(new StepOne());
pipeline.addStep(new StepTwo());
pipeline.addStep(new StepThree());
pipeline.execute();
}
}
然而,正如您所看到的,简单的实现有很多限制。
其中一个主要问题是,由于要求每个步骤的输出可以是任何类型,因此天真的实现不是类型安全的(Pipeline 类中的 execute 方法)。如果我碰巧错误地连接了管道中的步骤,应用程序将失败。
任何人都可以通过添加到我编码的内容来帮助我设计解决方案,或者指出我已经存在的模式来解决这个问题吗?
原文由 Prashant Chauhan 发布,翻译遵循 CC BY-SA 4.0 许可协议
我会专注于
是的,这是一个问题。
StepThree
是这里的陌生人。我不认为一个简单的模式可能有帮助,我确实认为它必须是策略和构建器模式的组合。例如:管道是这样的:
使用 fast-builder-syntax 这可能有效:
这应该有效,因为泛型不是字节码的一部分。