资讯专栏INFORMATION COLUMN

重构-改善既有代码的设计(十一)--处理概括关系

sherlock221 / 488人阅读

摘要:构造函数比较难以向上拉动,因此专门有一个构造函数本体上移处理它,一般不会将构造函数往下推,因为以工厂函数取代构造函数通常更管用。

前言

有一批重构手法专门用来处理概括关系(即继承关系),主要是将函数上下移动于继承体系之中字段上移和方法上移都用于将特性向继承体系的上端移动,字段下移和方法下移则将特性向继承体系的下端移动。构造函数比较难以向上拉动,因此专门有一个构造函数本体上移处理它,一般不会将构造函数往下推,因为以工厂函数取代构造函数通常更管用。

字段上移 问题

两个子类拥有相同的字段

方法

将该字段上移

动机

既然是相同字段就应该放在父类中

函数上移 问题

有些函数,在各个子类中产生完全相同的效果

方法

将该函数移至超类

动机

相同效果的方法应该可以做成一个方法吧。

构造函数本体上移 问题

在各个子类中拥有一些构造函数,他们的本体几乎完全一致

方法

在超类中新建一个构造函数,并在子类构造函数中调用它

动机

又是重复代码。。。

函数下移 问题

超类中的某个函数只与部分(而非全部)子类有关

方法

将这个函数移到相关的子类去

动机

这个就是依恋关系。直接迁移函数

字段下移 问题

超类中的某个字段只被部分(而非全部)子类用到

方法

将这个字段移到需要它的那些子类去

动机

这个就是依恋关系。直接迁移字段

提炼子类 问题

类中的某些特性只被某些(而非全部)实例用到

方法

新建一个子类,将上面所说的那一部分特性移到子类中

动机

说明这个类并不是只做一件事。而且还比较重。需要拆分

提炼超类 问题

两个类有相似的特性

方法

为这两个类建立一个超类,将相同特性移至超类

动机

用父类来封装相似的特性,用子类来新特性

# 提炼接口

问题

若干客户使用类接口中的同一子集,或者两个类的接口有部分相同

方法

将相同的子集提炼到一个独立的接口中

动机

同上

折叠继承体系 问题

超类和子类之间没有太大的区别

方法

将它们合为一体

动机

根据具体情况而用

塑造模板函数 问题

有一些子类,其中相应的某些函数以相同顺序执行类似的操作,但各个操作的细节上有所不同

方法

将这些操作分别放进独立函数中,并操持它们都有相同的签名,于是原函数也就变得相同了,然后将原函数上移至超类。

动机

比如java的泛型,就是模板函数,能够大大减少代码重复

以委托取代继承 问题

某个子类只使用超类接口中的一部分,或是根本不需要继承而来的数据

方法

在子类中新建一个字段用以保存超类,调整子类函数,令它改而委托超类,然后去掉两者之间的继承关系。

动机

如果只使用方法的话,可以这样使用

以继承取代委托 问题

在两个类之间使用委托关系,并经常为整个接口编写许多极简单的委托函数。

方法·

让委托类继承受托类

动机

太简单的委托是没有必要的。只会增加代码量。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/71128.html

相关文章

  • Java学习路线总结,搬砖工逆袭Java架构师(全网最强)

    摘要:哪吒社区技能树打卡打卡贴函数式接口简介领域优质创作者哪吒公众号作者架构师奋斗者扫描主页左侧二维码,加入群聊,一起学习一起进步欢迎点赞收藏留言前情提要无意间听到领导们的谈话,现在公司的现状是码农太多,但能独立带队的人太少,简而言之,不缺干 ? 哪吒社区Java技能树打卡 【打卡贴 day2...

    Scorpion 评论0 收藏0
  • 重构---改善既有代码设计

    摘要:为何重构重构有四大好处重构改进软件设计如果没有重构,程序的设计会逐渐腐败变质。经常性的重构可以帮助维持自己该有的形态。你有一个大型函数,其中对局部变量的使用使你无法采用。将这个函数放进一个单独对象中,如此一来局部变量就成了对象内的字段。 哪有什么天生如此,只是我们天天坚持。 -Zhiyuan 国庆抽出时间来阅读这本从师傅那里借来的书,听说还是程序员的必读书籍。 关于书的高清下载连...

    baihe 评论0 收藏0
  • 重构-改善既有代码设计(七)-- 在代码之间搬移特性

    摘要:前言决定把责任放在哪对于对象设计是最重要的之一。重构可以很好的解决这个问题。方法建立一个新类,将相关的字段和函数从旧类搬移到新类。方法将这个类的所有特性搬移到另一个类中,然后移除原类。让这个扩展品成为源类的子类或包装类。 前言 决定把责任放在哪对于对象设计是最重要的之一。重构可以很好的解决这个问题。以下是笔者的重构方法注:客户:调用接口客户类:使用了接口的类服务类:提供服务的类 Mov...

    solocoder 评论0 收藏0
  • 重构-改善既有代码设计(一)--重构,第一个案例

    摘要:并根据目录选读第章重构,第一个案例这是只是一个方法。绝大多数情况下,函数应该放在它所使用的数据的所属对象内最好不要在另一个对象的属性基础上运用语句。 什么是重构 在不改变代码外在行为的前提下,对代码做出修改以改进程序内部的结构简单地说就是在代码写好后改进它的设计 谁该阅读这本书 专业程序员(能够提高你的代码质量) 资深设计师和架构规划师(理解为什么需要重构,哪里需要重构) 阅读技巧...

    acrazing 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<