zoukankan      html  css  js  c++  java
  • 31天重构学习笔记14. 分离职责

    摘要:由于最近在做重构的项目,所以对重构又重新进行了一遍学习和整理,对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查看原文。

    概念:本文中的“分离职责”是指当一个类有许多职责时,将部分职责分离到独立的类中,这样也符合面向对象的五大特征之一的单一职责原则,同时也可以使代码的结构更加清晰,维护性更高。

    正文:如下代码所示,Video类有两个职责,一个是处理video rental,另一个是计算每个客户的总租金。我们可以将这两个职责分离出来,因为计算每个客户的总租金可以在Customer计算,这也比较符合常理。

    using System.Collections.Generic;
    using System.Linq;

    namespace LosTechies.DaysOfRefactoring.BreakResponsibilities.Before
    {
        public class Video
      
    {
            public void PayFee(decimal fee)
            {
            }

            public void RentVideo(Video video, Customer customer)
            {
                customer.Videos.Add(video);
            }

            public decimal CalculateBalance(Customer customer)
            {
                returncustomer.LateFees.Sum();
            }
        }

        public class Customer
      
    {
            public IList<decimal> LateFees { get; set; }
            public IList<Video> Videos { get; set; }
        }
    }

    重构后的代码如下,这样Video 的职责就变得很清晰,同时也使代码维护性更好。

    using System.Collections.Generic;
    using System.Linq;

    namespace LosTechies.DaysOfRefactoring.BreakResponsibilities.After
    {
        public class Video
       
    {
            public void RentVideo(Video video, Customer customer)
            {
                customer.Videos.Add(video);
            }
        }

        public class Customer
       
    {
            public IList<decimal> LateFees { get; set; }
            public IList<Video> Videos { get; set; }

            public void PayFee(decimal fee)
            {
            }

            public decimal CalculateBalance(Customer customer)
            {
                return customer.LateFees.Sum();
            }
        }
    }

    总结:这个重构经常会用到,它和之前的“移动方法”有几分相似之处,让方法放在合适的类中,并且简化类的职责,同时这也是面向对象五大原则之一和设计模式中的重要思想。

  • 相关阅读:
    Could A New Linux Base For Tablets/Smartphones Succeed In 2017?
    使用libhybris,glibc和bionic共存时的TLS冲突的问题
    6 Open Source Mobile OS Alternatives To Android in 2018
    Using MultiROM
    GPU drivers are written by the GPU IP vendors and they only provide Android drivers
    Jolla Brings Wayland Atop Android GPU Drivers
    How to Use Libhybris and Android GPU Libraries with Mer (Linux) on the Cubieboard
    闲聊Libhybris
    【ARM-Linux开发】wayland和weston的介绍
    Wayland and X.org problem : Why not following the Android Solution ?
  • 原文地址:https://www.cnblogs.com/KnightsWarrior/p/1766758.html
Copyright © 2011-2022 走看看