原文出自 http://www.cnblogs.com/ggjucheng/archive/2012/12/04/2802311.html
英文出自 http://docs.oracle.com/javase/tutorial/java/IandI/nogrow.html
考虑你已经开发了一个名称为DoIt
的接口
public interface DoIt { void doSomething(int i, double x); int doSomethingElse(String s); }
假设最近你要为DoIt
添加第三个方法,所以接口变为:
public interface DoIt { void doSomething(int i, double x); int doSomethingElse(String s); boolean didItWork(int i, double x, String s); }
如果做个这个改变,所有继承老接口DoIt的类都要出错,因为他们没有全部实现这个接口。依靠这个接口的程序员会大声抗议。
尝试让你的接口从一开始就完全预见到的所有用途。这往往是不可能的,你可能需要创建更多的接口。例如,可以创建一个DoItPlus的接口扩展DoIt
:
public interface DoItPlus extends DoIt { boolean didItWork(int i, double x, String s); }
现在,你的代码的用户可以选择继续使用旧的接口或升级到新的接口。