[改善Java代码]在接口中不要存在实现代码

第3章  类、对象及方法

书读得多而不思考,你会觉得自己知道的很多。

书读得多而思考,你会觉得自己不懂的越来越多。

—伏尔泰

在面向对象编程(Object-Oriented Programming,OOP)的世界里,类和对象是真实世界的描述工具,方法是行为和动作的展示形式,封装、继承、多态则是其多姿多彩的主要实现方式,如此,OOP才会像现在这样繁荣昌盛、欣欣向荣。

本章主要讲述关于Java类、对象、方法的种种规则、限制及建议,让读者在面向对象编程的世界中走得更远,飞得更高。

建议31: 在接口中不要存在实现代码

看到这样的标题读者可能会纳闷:接口中有实现代码?这怎么可能呢?确实,接口中可以声明常量,声明抽象方法,也可以继承父接口,但就是不能有具体实现,因为接口是一种契约(Contract),是一种框架性协议,这表明它的实现类都是同一种类型,或者是具备相似特征的一个集合体。对于一般程序,接口确实没有任何实现,但是在那些特殊的程序中就例外了,阅读如下代码:

 1 public class Client {
 2     public static void main(String[] args) {
 3         // 调用接口的实现
 4         B.s.doSomething();
 5     }
 6 }
 7 
 8 // 在接口中存在实现代码
 9 interface B {
10     public static final S s = new S() {
11         public void doSomething() {
12             System.out.println("我在接口中实现了");
13         }
14     };
15 }
16 
17 // 被实现的接口
18 interface S {
19     public void doSomething();
20 }

仔细看main方法,注意那个B接口。它调用了接口常量,在没有任何显式实现类的情况下,它竟然打印出了结果,那B接口中的s常量(接口是S)是在什么地方被实现的呢?答案是在B接口中。

在B接口中声明了一个静态常量s,其值是一个匿名内部类(Anonymous Inner Class)的实例对象,就是该匿名内部类(当然,可以不用匿名,直接在接口中实现内部类也是允许的)实现了S接口。你看,在接口中存在着实现代码吧!

这确实很好,很强大,但是在一般的项目中,此类代码是严禁出现的,原因很简单:这是一种不好的编码习惯,接口是用来干什么的?接口是一个契约,不仅仅约束着实现者,同时也是一个保证,保证提供的服务(常量、方法)是稳定、可靠的,如果把实现代码写到接口中,那接口就绑定了可能变化的因素,这就会导致实现不再稳定和可靠,是随时都可能被抛弃、被更改、被重构的。所以,接口中虽然可以有实现,但应避免使用。

注意 接口中不能存在实现代码。

原文地址:https://www.cnblogs.com/DreamDrive/p/5425119.html