1700455401
4.1 接口隔离原则的定义
1700455402
1700455403
在讲接口隔离原则之前,先明确一下我们的主角——接口。接口分为两种:
1700455404
1700455405
❑实例接口(Object Interface),在Java中声明一个类,然后用new关键字产生一个实例,它是对一个类型的事物的描述,这是一种接口。比如你定义Person这个类,然后使用Person zhangSan=new Person()产生了一个实例,这个实例要遵从的标准就是Person这个类,Person类就是zhangSan的接口。疑惑?看不懂?不要紧,那是因为让Java语言浸染的时间太长了,只要知道从这个角度来看,Java中的类也是一种接口。
1700455406
1700455407
❑类接口(Class Interface),Java中经常使用的interface关键字定义的接口。
1700455408
1700455409
主角已经定义清楚了,那什么是隔离呢?它有两种定义,如下所示:
1700455410
1700455411
❑Clients should not be forced to depend upon interfaces that they don’t use.(客户端不应该依赖它不需要的接口。)
1700455412
1700455413
❑The dependency of one class to another one should depend on the smallest possible interface.(类间的依赖关系应该建立在最小的接口上。)
1700455414
1700455415
新事物的定义一般都比较难理解,晦涩难懂是正常的。我们把这两个定义剖析一下,先说第一种定义:“客户端不应该依赖它不需要的接口”,那依赖什么?依赖它需要的接口,客户端需要什么接口就提供什么接口,把不需要的接口剔除掉,那就需要对接口进行细化,保证其纯洁性;再看第二种定义:“类间的依赖关系应该建立在最小的接口上”,它要求是最小的接口,也是要求接口细化,接口纯洁,与第一个定义如出一辙,只是一个事物的两种不同描述。
1700455416
1700455417
我们可以把这两个定义概括为一句话:建立单一接口,不要建立臃肿庞大的接口。再通俗一点讲:接口尽量细化,同时接口中的方法尽量少。看到这里大家有可能要疑惑了,这与单一职责原则不是相同的吗?错,接口隔离原则与单一职责的审视角度是不相同的,单一职责要求的是类和接口职责单一,注重的是职责,这是业务逻辑上的划分,而接口隔离原则要求接口的方法尽量少。例如一个接口的职责可能包含10个方法,这10个方法都放在一个接口中,并且提供给多个模块访问,各个模块按照规定的权限来访问,在系统外通过文档约束“不使用的方法不要访问”,按照单一职责原则是允许的,按照接口隔离原则是不允许的,因为它要求“尽量使用多个专门的接口”。专门的接口指什么?就是指提供给每个模块的都应该是单一接口,提供给几个模块就应该有几个接口,而不是建立一个庞大的臃肿的接口,容纳所有的客户端访问。
1700455418
1700455419
1700455420
1700455421
1700455423
设计模式之禅 4.2 美女何其多,观点各不同
1700455424
1700455425
我们举例来说明接口隔离原则到底对我们提出了什么要求。现在男生对小姑娘的称呼,使用频率最高的应该是“美女”了吧,你在大街上叫一声:“嗨,美女!”估计10个有8个回头,其中包括那位著名的如花。美女的标准各不相同,首先就需要定义一下什么是美女:首先要面貌好看,其次是身材要窈窕,然后要有气质,当然了,这三者各人的排列顺序不一样,总之要成为一名美女就必须具备:面貌、身材和气质,我们用类图体现一下星探(当然,你也可以把自己想象成星探)找美女的过程,如图4-1所示。
1700455426
1700455427
1700455428
1700455429
1700455430
图4-1 星探寻找美女的类图
1700455431
1700455432
定义了一个IPettyGirl接口,声明所有的美女都应该有goodLooking、niceFigure和great-Temperament,然后又定义了一个抽象类AbstractSearcher,其作用就是搜索美女并显示其信息,只要美女都按照这个规范定义,Searcher(星探)就轻松多了,美女类的实现如代码清单4-1所示。
1700455433
1700455434
代码清单4-1 美女类
1700455435
1700455436
public interface IPettyGirl{
1700455437
1700455438
//要有姣好的面孔
1700455439
1700455440
public void goodLooking();
1700455441
1700455442
//要有好身材
1700455443
1700455444
public void niceFigure();
1700455445
1700455446
//要有气质
1700455447
1700455448
public void greatTemperament();
1700455449
[
上一页 ]
[ :1.7004554e+09 ]
[
下一页 ]