ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

9、基于接口而非实现编程

2021-06-09 21:01:23  阅读:161  来源: 互联网

标签:基于 封装 实现 编程 接口 抽象 接口定义


这个原则非常重要,是一种非常有效的提高代码质量的手段,在平时的开发中经常被用到
基于接口而非实现编程这条原则中的接口,可以理解为编程语言中的接口或者抽象类

接口定义

接口就是一组协议或者约定,是功能提供者提供给使用者的一个功能列表

设计初衷

讲接口和实现相分离,封装不稳定的实现,暴露稳定的接口。上游系统面向接口而非实现编程,不依赖不稳定的实现细节,这样当实现发生变化的时候,上游系统的代码基本上不需要做改动,一次来降低代码间的耦合性,提高代码的扩展性

遵从基于接口而非实现编程原则
  • 函数的命名不能暴露任何实现细节。比如,前面提到的uploadToAliyun() 就不符合要求,应该改为去掉aliyun这样的字眼,改为更加抽象的命名方式,比如:upload()
  • 封装具体的实现细节。比如,跟阿里云相关的特殊上传(或下载)流程不应该暴露给调用者。我们对上传(或下载)流程进行封装,对外提供一个包裹所有上传(或下载)细节的方法,给调用者使用
  • 为实现类定义抽象的接口。具体实现类都依赖统一的接口定义,遵从一致的上传功能协议。使用者依赖接口,而不是具体的实现类来编程。
我们在做软件开发的时候,一定要有抽象意识,封装意识,接口意识。在定义接口的时候,不要暴露任何实现细节。接口定义只表明做什么,而不是怎么做。而且,在设计接口的时候,我们要多思考一下,这样的接口设计是否足够通用,是否能够做到在替换具体的接口实现的时候,不需要任何接口定义的改动
需要掌握
  • 基于接口而非实现编程,这条原则的另一个表达式,是基于抽象而非实现编程。后者的表述方式其实更能体现这条原则的设计初衷。我们在做软件开发的时候,一定要有抽象意识,封装意识,接口意识。约抽象、越顶层、越脱离具体某一实现的设计,越能提高代码的灵活性、扩展性、可维护性
  • 我们在定义接口的时候,一方面,命名要足够通用,不能包含具体实现相关的字眼;另一方面,与特定实现有关的方法不要定义在接口中。
  • 基于接口而非实现编程原则,不仅仅可以知道非常细节的编程开发,还能知道更加上层的架构设计、系统设计等。比如,服务端与客户端之间的接口设计、类库的接口设计

标签:基于,封装,实现,编程,接口,抽象,接口定义
来源: https://blog.csdn.net/sunbing_sk/article/details/117715778

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有