Reusability1
Reusability1. 复用的层面1.1 代码级别复用顾名思义,代码复用就是把代码都搬过来,这是最主要的复用 1.1.1 白盒复用白盒的意思就是里面的东西我们都知道是什么,具体实现的方式也知道,直接把源代码复制过来,可以根据自己的实际需求修改里面的代码(这个应该是最熟悉的,毕竟我们以前写作业遇到不会的就是这么写的嘛) 优点:个性化、可定制化程度高 缺点:增加了软件的复杂度,需要对源代码有一定的了解 1.1.2 黑盒复用黑盒的意思是里面的东西不知道是什么,也没法改,只知道怎么用(详情参加微积分学习方法hh) 优点:简单、清晰 缺点:适应性差一些 1.2 模块级别复用一般来说就是把封装好的类、接口等等直接拿过来用,根据它的spec来复用 1.3 类库级别复用例如Java Library 像我们平时用的一些API例如Map,Set,List都属于这一方面 1.4 系统级别的复用:框架(Framwork)1.4.1 框架的定义里面有一系列的抽象类、具体类以及对应的spec却没有具体实现,需要开发者自己根据spec进行代码填充 只有骨架,没有血肉。 Framework作为主程序执行,调用开发者写的具体实现; 开发者根据Framework预留的接口实现 可以将框架看作是更大规模的API复用,除了提供可复用的API, 还将这些模块之间的关系都确定了下来,等于说就是复用了一个系统,系统的内容由我们开发者自己填写 1.4.2 领域复用实现一个系统(框架)需要将抽象类中的一些抽象方法进行具体的实现或者针对特定的应用增加新的方法。 1.4.2.1 Hook Method通过重写方法的方式实现在一个应用当中对框架的扩展。它可以降低接口和应用的需求之间的耦合度(依赖性) 我的理解是API内部有实现方法,但不能够直接拿来用,Hook Method是将用户需求和API内部实现方法连接起来的,有点类似于设计模式中的template模式。 1.4.2.2 Inversion of Control一般来说都是由写代码的人来控制各个接口、类之间的关系,但对于框架来说这都是定死的了,实现者无法修改框架中类之间的关系 带来了好处就是降低了对象之间的依赖程度,提供灵活性和可维护性 1.4.2.3 Non-modifiable framework code框架中的代码是无法改变的,实现者只能扩展功能, 但不能修改基本功能 1.4.3 框架设计1.4.3.1 框架根据应用的不同而不同框架本身设计是为了解决不同类型的问题而不是针对某一单一问题,因此它更像是一个模板,所以对于不同类型的应用,框架的设计不同 1.4.3.1 框架扩展方式1.4.3.1.1 白盒框架之前提到过白盒的意思是知道里面的东西是什么,所以可以通过inheritance,override,dynamic binding来扩展框架 1.4.3.1.2 黑盒框架黑盒是我们不知道里面有什么,只知道怎么用。 类似于插件,通过spec了解某个模块的作用然后直接调用这个模块实现某个功能也就是delegation (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |