对接口有新的需求,应如何处理?

在通用组件API设计中,如果有接口的变更需求,怎么做才能既能实现新的需求,又能与以往使用这个组件的系统兼容,并且又尽量不增加我们维护接口的工作量呢?

例如以下的场景:

有接口A

其实现的方法C

现在有新的需求:在原来的接口的方法中增加一个参数。我们应该怎么去做?

如果我们直接修改原来的接口,改为:

这样做会导致以前所用支持接口A的系统都需要根据我们的变化进行修改,会导致使用我们接口的系统不可取。可以使用下面的方法:

方法一. 定义一个新的接口,扩展原来的接口,并且在里面定义我们需要的新的方法,这样原来的系统使用新的接口也仍然是支持的:

对于原先实现接口A的类C,使其去实现接口B中的方法:

这样,对外公开的接口有接口A没有变,只改变了它的实现方法,对于原来使用接口A的系统,并不会由于组件的变化而产生额外的影响。

方法二: 定义一个新的接口B,使之扩展接口A:

让原来的类C实现接口B:

方法二的接口B因为扩展了接口A,接口之间存在依赖关系,所以使用方法一会更利于接口的维护。

你可能感兴趣的:(接口)