`
圣殿骑士
  • 浏览: 46063 次
  • 性别: Icon_minigender_1
  • 来自: 新加坡
社区版块
存档分类
最新评论

31天重构学习笔记1. 封装集合

 
阅读更多

摘要:由于最近在做重构的项目,所以对重构又重新进行了一遍学习和整理,对31天重构最早接触是在2009年10月份,由于当时没有订阅Sean Chambers的blog,所以是在国外的社区上闲逛的时候链接过去的。记得当时一口气看完了整个系列并没有多少感觉,因为这些基本上项目都在使用,只是我们没有专门把它标示和整理出来,所以也没有引起多大的重视。现在突然接手这个重构项目,由于团队成员技术和经验参差不齐,所以有必要专门整理一个重构的纲要,当然这个系列也非常适合做新系统的代码规范参考,只要有代码的地方,这个重构规范就很有价值。周末也不想出去闲逛,因为在刚到这个美丽的城市,没有亲戚或者朋友,所以才能静下心来两天时间写完这个重构参考规范。同时也感受了Windows Live writer写文章的快感。当然重构的整体架构得另当别论(整体架构在我的这篇文章有专门的讲解(http://www.cnblogs.com/zenghongliang/archive/2010/06/23/1763438.html)。大的架构设计好了以后,这些重构细节点就成了东风之后的大火,对整个项目也是至关重要。31天重构这个系列和《代码大全》、《重构:改善既有代码的设计》比较起来最大的特点就是比较简单、浅显易懂。那么我这些文章也都是学习Sean Chambers的31天重构的笔记整理,所以如果大家对这个笔记有任何异议也可以指出。

具体也可以通过http://www.lostechies.com/blogs/sean_chambers/archive/2009/07/31/31-days-of-refactoring.aspx查看原文。

概念:本文所讲的封装集合就是把集合进行封装,只提供调用端需要的接口。

正文:在很多时候,我们都不希望把一些不必要的操作暴露给调用端,只需要给它所需要的操作或数据就行,那么做法就是封装。这个重构在微软的代码库也经常遇到。比如最经典的属性对字段的封装就是一个很好的例子,那么下面我们将看到对集合的封装,如下代码所示,调用端只需要一个集合的信息,而我们则提供了一个IList的集合,大家都知道IList具有对集合的所有操作,所以这会带来很多隐患,最好的做法就是对它进行重构。

using System.Collections.Generic;

namespace LosTechies.DaysOfRefactoring.EncapsulateCollection.Before
{
public class Order
{
private List<OrderLine> _orderLines;
private double _orderTotal;

public IList<OrderLine> OrderLines
{
get { return _orderLines; }
}

public void AddOrderLine(OrderLine orderLine)
{
_orderTotal += orderLine.Total;
_orderLines.Add(orderLine);
}

public void RemoveOrderLine(OrderLine orderLine)
{
orderLine = _orderLines.Find(o => o == orderLine);

if (orderLine == null)
return;

_orderTotal -= orderLine.Total;
_orderLines.Remove(orderLine);
}
}

public class OrderLine
{
public double Total { get; private set; }
}
}

那么重构之后,我们把IList换成了IEnumerable,大家都知道只包括一个返回值为IEnumerator的GetEnumerator()方法,所以这样只能遍历取出它的值,而不能对这个集合做出改变,这正是我们所需要的结果,具体代码如下:

using System.Collections.Generic;

namespace LosTechies.DaysOfRefactoring.EncapsulateCollection.After
{
public class Order
{
private List<OrderLine> _orderLines;
private double _orderTotal;

public IEnumerable<OrderLine> OrderLines
{
get { return _orderLines; }
}

public void AddOrderLine(OrderLine orderLine)
{
_orderTotal += orderLine.Total;
_orderLines.Add(orderLine);
}

public void RemoveOrderLine(OrderLine orderLine)
{
orderLine = _orderLines.Find(o => o == orderLine);

if (orderLine == null)
return;

_orderTotal -= orderLine.Total;
_orderLines.Remove(orderLine);
}
}

public class OrderLine
{
public double Total { get; private set; }
}
}

总结:这个例子很容易让我们想到以前系统间耦合常喜欢用数据库。每个系统都会操作数据库,并且有些系统还会对数据库的表结构或字段进行修改,那么这很容易就会造成维护的地狱,很明智的一个做法就是使用SOA来隔开这些耦合,让一些只需要数据展示的系统得到自己需要的数据即可。

分享到:
评论

相关推荐

    [免费高清PDF]31天重构系列笔记.rar

    《31天重构系列笔记》是一本专注于C#编程语言重构技术的教程,该资源以免费高清PDF的形式提供。重构是软件开发过程中的一种重要实践,它旨在改进代码结构,提高可读性和可维护性,而不会改变外部行为。在31天的时间...

    31天重构学习笔记.docx

    【封装集合】是软件开发中的一个重要概念,尤其在追求高质量代码的过程中,封装是面向对象编程的基本原则之一。本文主要讨论了如何通过重构来优化代码,避免将集合的全部操作暴露给调用者,以提高代码的安全性和可...

    31天重构学习笔记中文版

    #### 2.1 集合的封装(Encapsulate Collection) - **原始代码**:使用`IList&lt;T&gt;`作为集合暴露接口,允许外部直接修改集合内容。 - **问题分析**:直接暴露集合可能导致集合状态被意外修改,增加维护难度。 - **...

    计算机行业AIGC投资机会梳理:ChatGPT快速流行,重构AI商业模式.zip

    计算机行业AIGC投资机会梳理:ChatGPT快速流行,重构AI商业模式.zip计算机行业AIGC投资机会梳理:ChatGPT快速流行,重构AI商业模式.zip计算机行业AIGC投资机会梳理:ChatGPT快速流行,重构AI商业模式.zip计算机行业...

    重构.part1.rar

    重构.part1.rar

    课程设计-基于知识图谱的应天门遗址数字重构展示平台源码.zip

    课程设计-基于知识图谱的应天门遗址数字重构展示平台源码.zip课程设计-基于知识图谱的应天门遗址数字重构展示平台源码.zip课程设计-基于知识图谱的应天门遗址数字重构展示平台源码.zip课程设计-基于知识图谱的应天门...

    重构.part2.rar(Martin Flower)

    Martin Flower 写的经典书籍。介绍如何对c++,java进行重构的书籍 &lt;br&gt;共有四个文件: 重构.part4.rar 重构.part3.rar 重构.part2.rar 重构.part1.rar

    重构.part3.rar(Martin Flower)

    Martin Flower 写的经典书籍。介绍如何对c++,java进行重构的书籍 &lt;br&gt;共有四个文件: 重构.part4.rar 重构.part3.rar 重构.part2.rar 重构.part1.rar

    31天重构速成

    ### 31天重构速成:重要重构技巧详解 #### 一、简介 重构作为软件开发过程中的一个重要环节,旨在不改变程序外部行为的前提下优化其内部结构,从而提高代码的可读性和可维护性。本篇文章将根据《31天重构速成》这...

    31天重构速成_中文版.pdf

    通过学习《31天重构速成》中的各种技巧,开发者可以逐步提升自己的重构能力,从而使代码更加健壮、优雅。以上是对《31天重构速成》中提到的主要知识点的详细解释,希望能够对学习重构的朋友有所帮助。

    《重构商业:产业互联网时代的商业模式重构》读书笔记模板.pptx

    《重构商业:产业互联网时代的商业模式重构》读书笔记模板.pptx

    重构.part4.rar(Martin Flower)

    Martin Flower 写的经典书籍。介绍如何对c++,java进行重构的书籍 &lt;br&gt;共有四个文件: 重构.part4.rar 重构.part3.rar 重构.part2.rar 重构.part1.rar

    如何改善代码的设计-读《重构》读书笔记.pdf

    1. **重构的意义**: - 重构有助于改进软件设计,因为代码的阅读和修改频率远高于编写。 - 重构可以使代码更易理解,就像擦亮窗户,让开发者看得更远。 - 重构可以帮助找到隐藏的bug,同时提升编程效率。 2. **...

    重构.part2.rar

    重构.part2.rar

    Piranha过时代码自动重构工具 v0.3.24.zip

    同时,它也是一个很好的学习工具,帮助初学者理解代码重构的重要性和实践方法。 在提供的压缩包文件中,“说明.htm”可能是Piranha的使用指南或详细说明文档,包含了如何安装、配置以及使用Piranha的步骤和注意事项...

    [重构与模式].(美国)Joshua.Kerievsky.清晰版 pdf (1)

    [重构与模式].(美国)Joshua.Kerievsky.清晰版 pdf (1) 全部pdf,共 2 卷

Global site tag (gtag.js) - Google Analytics