欢迎来到天天文库
浏览记录
ID:37598738
大小:748.81 KB
页数:33页
时间:2019-05-12
《面向接口而非实现进行编程》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第六章面向接口而非实现进行编程6第六章API是文档的说明和接口的说明总称。通常类的组成是包括公开和非公开的成员两部分。上一章说到:API公开的内容越少越好。将代码分成接口和实现两部分,在编写代码时,让系统的其它部分只依赖于接口这是我们呈现设计的习惯。接口是用来公开给使用只的说明部分,实现是类内部的具体实现过程。方法添加容易与移去难设计者带来的问题往往远远多于其解决的问题。向API中添加一个新方法是很容易的一件事,但与此相反,想从API中移徐一个方法却非常困难。一个API对外提供的功能越多,那么为保持向后兼容性所做的
2、工作也就越多。提供的功能越多留给具体实现的空间也就越少。如果API公开的不必要的内容越多,可改进的空间也就越少。方法的添加与移去1代码不是API:需要经过抽象的说明才是API,没有经过重构,那么公开的很可能不是API,而是内部的具体实现。千万不要把代码当成API,还要花精力来整理。2公布的是接口不是实现:给调用者是接口应用,不是公布类的具体实现描述。3逻辑分离与物理分离:只是把类说明,和类实现分离,但文件还是在以前。4物理分离:接口说明和实现说明分别在两个不同的文件中,达到物理的分离。公布的是接口不是实现编程应该面
3、向接口而非现实:在使用API时,应该遵守正确的原则。不要依赖没说明的属性和文件资源:不要去依赖那些没有在文档中提起的属性和文件资源。提出合适API要求:正确的做事方法是向设计者要求提出合适API。那种自用示公开内容来完成某种功能的做法是非常脆弱的,会因为版本、环境的不同而无法正常运行。编程应该面向接口而非现实正确理解面向接口编程的概念Iterface只是接口说明:能够清楚地理解面向接口编程并不是对应着Java中的Iterface,这种编程方式只是将其抽象定义与实际的实现这两类内容进行分离。类的使用特点:何时使用类接
4、口使用特点:何时使用接口6.1移除方法或者字段不要随意移去方法和属性:(1)设计方法或属性在使用:(2)类会对相关的方法和属性设置访问权限。(3)类的成员被继承:设计方法或属性在使用从已经公开的类或者接口中移除方法或者字段是一件错误的事情。系统公开,可能说明给方法或属性具有一定使用代表性,这样就会有其他成员在使用。一个方法或者字段被定义为private或者是默认的package访问级别,那么对于外部代码来说,它是不可见的,也就无法进行访问。这种情况,从类中移除该内容,不会引起什么问题,但没什么意义。类对相关方法和属
5、性设置访问权限类的设计者肯定会对类的成员根据实际使用需要设置成:PUBLIC,PROTECTED,PRIVATE等,如果你移去,就会造成该给访问的没办法访问,不能访问的有多此一举。移去方法对于源代码和二进制来讲,移除一个抽象的proteced方法是可以兼容的。从功能角度来说,可能是并不兼容。那个方法当时被动放到类中,应该是有本应的目的,而子类也可能是会重载该是方法,并希望在合适的时候被动调用。他们的实现就不能被调用了,theMethod方法语义也发生了改变,则子类是无法重载这个方法的。6.2移除或者添加一个类或者接
6、口如果一个类或者接口可以被外部访问,就意味着其方法可能会被调用,或者其字段可能被引用,一旦类和接口成为API,两者就没什么区别了,都必须长久地存在下去。类和接口其实是没有很大区别,类强调封装性,接口强调调用方法或引用方法。6.3向现有的继承体系中添加接口或者类向现有的继承体系中添加类或者接口可以带来很多好处:(1)简化API:不必要公开那么多(2)引同更统一(3)维护更方便例子说明PublicabstractStringsayHello();PublicabstractStringsayHelloto(String
7、wgo);作者希望可以简化这个APIPublicabstractclassSimpleHelloClass{PublicabstractStringsayHello();}当然,以前编写的类仍然需要维护。PublicabstractclasshelloClassextendsSimpleHelloClass{}简单只需要维护这里就可以工厂方法支持参数化的返回类型(2)PublicfinalclassTemplateextendsobject{PrivatefinalClasstype;PublicTem
8、plate(Classtype{this.type=type;}PublicClassgetType(){returntype;}//nowwhat!?PublicTemplate(){this(object.class);}}工厂方法支持参数化的返回类型(3)PublicfinalclassTemplateextendsobject{Pr
此文档下载收益归作者所有