在通用组件API设计中,如果有接口的变更需求,怎么做才能既能实现新的需求,又能与以往使用这个组件的系统兼容,并且又尽量不增加我们维护接口的工作量呢?
例如以下的场景:
有接口A:
其实现的方法C:
现在有新的需求:在原来的接口的方法中增加一个参数。我们应该怎么去做?
如果我们直接修改原来的接口,改为:
这样做会导致以前所用支持接口A的系统都需要根据我们的变化进行修改,会导致使用我们接口的系统不可取。可以使用下面的方法:
方法一. 定义一个新的接口,扩展原来的接口,并且在里面定义我们需要的新的方法,这样原来的系统使用新的接口也仍然是支持的:
对于原先实现接口A的类C,使其去实现接口B中的方法:
这样,对外公开的接口有接口A没有变,只改变了它的实现方法,对于原来使用接口A的系统,并不会由于组件的变化而产生额外的影响。
方法二: 定义一个新的接口B,使之扩展接口A:
让原来的类C实现接口B:
方法二的接口B因为扩展了接口A,接口之间存在依赖关系,所以使用方法一会更利于接口的维护。