设计模式(三)之单一职责原则

简介: 单一职责原则:官方给的说法是,就一个类而言,应该仅有一个因其他变化的原因。说白了就是,一个类只负责一项职责。最简单也是最难的原则。难处在于对职责进行划分。单一职责原则提出了一个编写程序的标准,用“职责”或“变化原因”来衡量接口或类设计得是否优良,但是“职责”和“变化原因”都是不可度量的,因项目而异,因环境而异。软件设计真正要做的内容,就是发现职责并把那些职责互相分离。单一职责原则可以使类的复杂度降低,实现什么职责都有清晰明确的定义;类的可读性提高,复杂度降低;可读性提高了,代码就更容易维护;变更(需求是肯定会变)引起的风险(包括测试的难度,以及需要测试的范围)降低。

QQ图片20220424000853.jpg


单一职责原则:


官方给的说法是:就一个类而言,应该仅有一个因其他变化的原因。


说白了就是,一个类只负责一项职责。


最简单也是最难的原则。难处在于对职责进行划分。单一职责原则提出了一个编写程序的标准,用“职责”或“变化原因”来衡量接口或类设计得是否优良,但是“职责”和“变化原因”都是不可度量的,因项目而异,因环境而异。


软件设计真正要做的内容,就是发现职责并把那些职责互相分离。单一职责原则可以使类的复杂度降低,实现什么职责都有清晰明确的定义;类的可读性提高,复杂度降低;可读性提高了,代码就更容易维护;变更(需求是肯定会变)引起的风险(包括测试的难度,以及需要测试的范围)降低。


下边使用手机来举例:这个手机我们需要实现播放音乐和拍照片的功能。


不遵循单一设计模式:


主文件:Progam.cs


using System;
namespace simple
{
    class Program
    {
        static void Main(string[] args)
        {
            Imusic music = new Totol();
            Iphoto photo = new Totol();
            music.PutMusic();
            photo.PutPhoto();
            Console.ReadLine();
        }
    }
}


接口文件:Iphoto.cs


namespace simple
{
    interface Iphoto
    {
        /// <summary>
        /// 拍照片方法
        /// </summary>
        void PutPhoto();
    }
}


接口文件:Imusic


namespace simple
{
    interface Imusic
    {
        /// <summary>
        /// 播放音乐方法
        /// </summary>
        void PutMusic();
    }
}


子类文件:Totol.cs用于实现上面两个接口


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace simple
{
    public class Totol: Iphoto,Imusic
    {
        public void PutPhoto()
        {
            Console.WriteLine("拍照片");
        }
        public void PutMusic()
        {
            Console.WriteLine("放音乐");
        }
    }
}


上边的设计显然不符合单一职责原则,totol类中有两个功能,也就是说,我们调用其中任何一个功能的时候,都会引起这个类的变化。


下边我们使用单一职责原则来实现:说的很高大上,说白了就是将totol类中的两个功能分开。


主文件:Program.cs


using System;
namespace simple
{
    class Program
    {
        static void Main(string[] args)
        {
            //Imusic music = new Totol();
            //Iphoto photo = new Totol();
            Music music = new Music();
            Photo photo = new Photo();
            music.PutMusic();
            photo.PutPhoto();
            Console.ReadLine();
        }
    }
}


接口文件Iphoto.cs


namespace simple
{
    interface Imusic
    {
        /// <summary>
        /// 播放音乐方法
        /// </summary>
        void PutMusic();
    }
}


Imusic.sc


namespace simple
{
    interface Imusic
    {
        /// <summary>
        /// 播放音乐方法
        /// </summary>
        void PutMusic();
    }
}


子类Music.cs


using System;
namespace simple
{
    class Music:Imusic
    {
        public void PutMusic()
        {
            Console.WriteLine("放音乐");
        }
    }
}


子类:Photo.cs


using System;
namespace simple
{
    class Photo:Iphoto
    {
        public void PutPhoto()
        {
            Console.WriteLine("拍照片");
        }
    }
}


以上的代码只是一个比较弱智的小例子。理解大概意思就好。


可以用上边的例子继续举例,我们手机最基础的功能只要拍照和放音乐,现在我需要手机可以拍摄有声Gif动图,并且可以播放,那么再修改上,不遵循单一职责原则的类可能就会出现很多意向不到的问题。但是如果他是两个类的话,可能我们修改起来的复杂程度,需要考虑的限制就没有那么多。这个就是单一职责原则的好处。


但是这篇文章最开始的部分也提到了:这个最难的部分还是职责的分离,往往很多项目的奇葩需求和奇葩逻辑,我们没有办法将其分的清楚。所以这个只能尽量遵守,为后期代码的开发做一个好的铺垫。


因为,需求是会变的。



目录
相关文章
|
1月前
|
设计模式 PHP
PHP中的设计模式:单一职责原则在软件开发中的应用
【10月更文挑战第8天】 在软件开发中,设计模式是解决常见问题的经验总结,而单一职责原则作为面向对象设计的基本原则之一,强调一个类应该只有一个引起变化的原因。本文将探讨单一职责原则在PHP中的应用,通过实际代码示例展示如何运用该原则来提高代码的可维护性和可扩展性。
32 1
|
1月前
|
设计模式 存储 测试技术
PHP中的设计模式:单一职责原则在维护性提升中的应用
【10月更文挑战第3天】 在软件开发中,设计模式是解决常见问题的高效方案。本文聚焦于PHP开发,探讨如何运用单一职责原则优化代码结构,提高系统可维护性。通过分析实际案例,本文展示了单一职责原则在降低代码复杂性、增强代码可读性和促进团队协作方面的显著效果。此外,文章还将讨论在实际项目中实施单一职责原则时可能遇到的挑战及应对策略,旨在为PHP开发者提供实用的指导和启示。
29 2
|
2月前
|
设计模式 数据管理 测试技术
PHP中的设计模式:单一职责原则在实战项目中的应用
在软件开发中,设计模式是解决问题的最佳实践。本文通过分析单一职责原则(SRP),探讨了如何运用这一原则来提升PHP项目的可维护性和扩展性。我们将从实际案例出发,展示单一职责原则在业务逻辑分离、代码解耦和提高测试效率方面的应用。无论是新手还是经验丰富的开发者,都能从中获益,进而编写出更健壮、更灵活的PHP代码。
37 5
|
2月前
|
设计模式 安全 PHP
PHP中的设计模式:单一职责原则在实战中的应用
在软件开发中,设计模式是解决常见问题的成熟方案。本文将通过分析单一职责原则这一设计原则,探讨如何在PHP应用程序中应用这一原则来提高代码的可维护性、扩展性和灵活性。我们将从实际案例出发,展示单一职责原则的具体应用方法,并解释其对项目开发周期和质量的积极影响。无论你是PHP初学者还是经验丰富的开发者,都能从中获益,提升你的编程实践水平。
30 4
|
2月前
|
设计模式 存储 测试技术
PHP中的设计模式:单一职责原则深度解析
在软件开发的广袤天地中,设计模式如同璀璨星辰,指引着我们穿越复杂系统的迷雾。本文聚焦于PHP环境,深入探讨“单一职责原则”(SRP),这一面向对象设计的基石。不同于常规摘要的简短概述,本文将引导您逐步揭开SRP的神秘面纱,从理论精髓到实践路径,再到其在PHP中的应用实例,为您呈现一场关于代码清晰性、可维护性和扩展性的深度之旅。
|
3月前
|
设计模式 前端开发 JavaScript
React开发设计模式及原则概念问题之什么是设计模式,单一职责原则如何理解
React开发设计模式及原则概念问题之什么是设计模式,单一职责原则如何理解
|
5月前
|
设计模式 Java C++
设计模式 六大原则之单一职责原则
设计模式 六大原则之单一职责原则
|
6月前
|
设计模式 Java 数据安全/隐私保护
小谈设计模式(4)—单一职责原则
小谈设计模式(4)—单一职责原则
|
6月前
|
设计模式 存储 NoSQL
【设计模式】软件设计原则-单一职责原则
【1月更文挑战第12天】【设计模式】软件设计原则-单一职责原则
|
设计模式 Java
Java设计模式七大原则-单一职责原则
Java设计模式七大原则-单一职责原则
85 0

热门文章

最新文章

  • 1
    C++一分钟之-设计模式:工厂模式与抽象工厂
    42
  • 2
    《手把手教你》系列基础篇(九十四)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-下篇(详解教程)
    46
  • 3
    C++一分钟之-C++中的设计模式:单例模式
    53
  • 4
    《手把手教你》系列基础篇(九十三)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-上篇(详解教程)
    37
  • 5
    《手把手教你》系列基础篇(九十二)-java+ selenium自动化测试-框架设计基础-POM设计模式简介(详解教程)
    61
  • 6
    Java面试题:结合设计模式与并发工具包实现高效缓存;多线程与内存管理优化实践;并发框架与设计模式在复杂系统中的应用
    56
  • 7
    Java面试题:设计模式在并发编程中的创新应用,Java内存管理与多线程工具类的综合应用,Java并发工具包与并发框架的创新应用
    40
  • 8
    Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
    49
  • 9
    Java面试题:请列举三种常用的设计模式,并分别给出在Java中的应用场景?请分析Java内存管理中的主要问题,并提出相应的优化策略?请简述Java多线程编程中的常见问题,并给出解决方案
    105
  • 10
    Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
    75