Effective java中有一条原则,接口优于抽象类。 和抽象类相比,接口有很多有点,比如现有的类可以很容易实现新的接口,接口是实现mixi类型的理想选择,接口可以很方便的构造非层次结构的的框架(这一点抽象类就无法做到,因为java的单根继承机制)。
和抽象类相比,接口也有缺点,就是不允许提供方法上的实现。我们没有办法在接口上为实现类提供一些基础方法。
骨架实现的模式综合了接口和抽象类的优点。首先定义一个接口,然后提供一个抽象类,提供一些基本功能的实现。 用户新建类的时候只需要继承骨架实现的抽象类,就可以很方便的调用一些基本功能。这一点可以参考java提供的AbstractSet, AbstractMap等。
这样的骨架实现模式完全是因为java的接口不允许提供方法的实现。 java8开始,允许接口有default方法和static方法,我们完全可以把原来 骨架实现的抽象类里面的方法放到接口中,用default方法来实现。