在通用组件API设计中,如果有接口的变更需求,怎么做才能既能实现新的需求,又能与以往使用这个组件的系统兼容,并且又尽量不增加我们维护接口的工作量呢?
例如以下的场景:
有接口A:
interface A { void method1(String arg1, String arg2); }
其实现的方法C:
class C implements A { public void method1(String arg1, String arg2) { // method1(arg1, arg2) 方法体 } }
现在有新的需求:在原来的接口的方法中增加一个参数。我们应该怎么去做?
如果我们直接修改原来的接口,改为:
interface A { void method1(String arg1, String arg2, String arg3); }
这样做会导致以前所用支持接口A的系统都需要根据我们的变化进行修改,会导致使用我们接口的系统不可取。可以使用下面的方法:
方法一. 定义一个新的接口,扩展原来的接口,并且在里面定义我们需要的新的方法,这样原来的系统使用新的接口也仍然是支持的:
interface B { void method1(String arg1, String arg2, String arg3); }
对于原先实现接口A的类C,使其去实现接口B中的方法:
class C implements A,B { public void method1(String arg1, String arg2, String arg3) { //三个参数的方法体 } public void method1(String arg1, String arg2) { String defaultValue = ""; method1(arg1, arg2, defaultValue);//调用上面的处理方法,提供一个默认值作为第三个参数。 } }
这样,对外公开的接口有接口A没有变,只改变了它的实现方法,对于原来使用接口A的系统,并不会由于组件的变化而产生额外的影响。
方法二: 定义一个新的接口B,使之扩展接口A:
interface B extends A{ void method1(String arg1, String arg2, String arg3); }
让原来的类C实现接口B:
class C implements B { public void method1(String arg1, String arg2, String arg3) { //三个参数的方法体 } public void method1(String arg1, String arg2) { String defaultValue = ""; method1(arg1, arg2, defaultValue);//调用上面的处理方法,提供一个默认值作为第三个参数。 } }
方法二的接口B因为扩展了接口A,接口之间存在依赖关系,所以使用方法一会更利于接口的维护。
本文探讨了在不破坏现有系统兼容性的前提下如何对通用组件API进行变更,提出了两种有效的方法来实现接口的平滑升级。
1430

被折叠的 条评论
为什么被折叠?



