重构第21天 合并继承 (Collapse Hierarchy)

理解:本文中的”合并继承”是指如果子类的属性和方法也适合于基类,那么就可以移除子类,从而减少依赖关系。

详解:上一篇我们讲到“提取子类”重构是指当基类中的一个责任不被所有的子类所需要时,将这些责任提取到合适的子类中。而我们今天所要讲的的“合并继承”重构一般用在当我们觉得不需要子类的时候。

 1 public class Website
 2     {
 3         public string Title { get; set; }
 4         public string Description { get; set; }
 5         public IEnumerable<Webpage> Pages { get; set; }
 6     }
 7
 8     public class StudentWebsite : Website
 9     {
10         public bool IsActive { get; set; }
11     }

如上代码所示,StudentWebSite子类除了有一个属性用来说明网站是否是活动的外没有别的责任,在这种情形下我们意识到IsActive属性可以应用到所有的网站,所以我们可以将IsActive属性上移到基类中,并去掉StudentWebSite类。

1  public class Website
2     {
3         public string Title { get; set; }
4         public string Description { get; set; }
5         public IEnumerable<Webpage> Pages { get; set; }
6         public bool IsActive { get; set; }
7     }

这篇和上篇其实最主要论述了子类和父类的继承关系以及如何判断什么时候需要使用继承,一般我们都能处理好这些关系,所以相对比较简单。

时间: 2024-10-27 18:53:31

重构第21天 合并继承 (Collapse Hierarchy)的相关文章

合并继承

概念:本文中的"合并继承"是指如果子类的属性和方法也适合于基类,那么就可以移除子类,从而减少依赖关系. 正文:上一篇我们讲到"提取子类"重构是指当基类中的一个责任不被所有的子类所需要时,将这些责任提取到合适的子类中.而我们今天所要讲的的"合并继承"重构一般用在当我们觉得不需要子类的时候. 如下代码所示,StudentWebSite子类除了有一个属性用来说明网站是否是活动的外没有别的责任,在这种情形下我们意识到IsActive属性可以应用到所有的网

LeetCode 第21题 合并两个有序链表

/*将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. 示例: 输入:1->2->4, 1->3->4输出:1->1->2->3->4->4 Definition for singly-linked list. public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; } */ 1 class Solutio

小酌重构系列[21]&mdash;&mdash;避免双重否定

避免双重否定 在自然语言中,双重否定表示肯定.但是在程序中,双重否定会降低代码的可读性,使程序不易理解,容易产生错觉.人通常是用"正向思维"去理解一件事情的,使用双重否定的判断,需要开发者以"逆向思维"的方式去理解它的含义.另外,在写程序时,"!"符号很容易被疏忽和遗漏,一不小心则会编写出错误的代码,从而产生bug.所以,在程序中,我们应当尽量避免使用双重否定. 优惠券是否未被使用? 还是以在线商城给用户发放优惠券为例,由于优惠券的初始状态是未被

深入浅出数据结构C语言版(21)——合并排序

在讲解合并排序之前,我们先来想一想这样一个问题如何解决: 有两个数组A和B,它们都已各自按照从小到大的顺序排好了数据,现在我们要把它们合并为一个数组C,且要求C也是按从小到大的顺序排好,请问该怎么做? 这个问题非常容易解决,我们将A.B和C都视为队列,然后不断比较A和B的首部,取出其中更小的数据出队 http://pic.cnhubei.com/space.php?uid=4593&do=album&id=1092952http://pic.cnhubei.com/space.php?ui

LeetCode 第21题 合并有序链表

(一)题目描述 Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists. Example: Input: 1->2->4, 1->3->4 Output: 1->1->2->3->4->4 (二)算法描述 1 先创建一个头结点,用

《重构——改善既有代码的设计》读书笔记

重构--改善既有代码的设计 1 重构概述 1.1 重构的概念(What) Refactoring 名词:对软件内部结构的一种调整,目的是在不改变软件可观察行为的前提下,提高其可理解性,降低修改成本. 动词:使用一系列重构方法,在不改变软件可观察行为的前提下,调整其结构. 1.2 为什么要重构(Why) 改进软件设计 提高代码质量和可读性,使软件系统更易理解和维护 帮助尽早的发现缺陷 提高编程速度 1.3 何时重构(When) 何时重构: 1)随时随地进行. 2)三次法则:第一次做某件事只管去做:

C#重构经典全面汇总

C#重构经典全面汇总 1.  封装集合 概念:本文所讲的封装集合就是把集合进行封装,仅仅提供调用端须要的接口. 正文:在非常多时候,我们都不希望把一些不必要的操作暴露给调用端,仅仅须要给它所须要的操作或数据即可,那么做法就是封装.这个重构在微软的代码库也常常遇到. 比方最经典的属性对字段的封装就是一个非常好的样例,那么以下我们将看到对集合的封装.例如以下代码所看到的,调用端仅仅须要一个集合的信息,而我们则提供了一个IList的集合.大家都知道IList具有对集合的全部操作,所以这会带来非常多隐患

【重构.改善既有代码的设计】11、处理概括关系【更优雅的继承】

11.处理概括关系[更优雅的继承] Pull Up Field(值域上移) 两个subclasses 拥有相同的值域.将此一值域移至superclass. Pull Up Method(函数上移) 有些函数,在各个subclass 中产生完全相同的结果.将该函数移至superclass. Pull Up Constructor Body(构造函数本体上移) 你在各个subclass 中拥有一些构造函数,它们的本体(代码)几乎完全一致. 在superclass 中新建一个构造函数,并在subcla

重构21-Collapse&#160;Hierarchy(去掉层级)

我们通过提取子类来下放职责.,当我们意识到不再需要某个子类时,可以使用Collapse Hierarchy重构.如果某个子类的属性(以及其他成员)可以被合并到基类中,这时再保留这个子类已经没有任何意义了. public class Website { public String title; public String description; public IEnumerable<Webpage> pages;} public class StudentWebsite extends Web