1、设计模式和原则总述

目录

一、什么是设计模式?有什么用?

二、设计模式

 三、设计原则


一、什么是设计模式?有什么用?

        设计模式是一套代码设计的经验总结,使用设计模式可以提高代码的重用性、可靠性,提交代码内聚,降低代码耦合。可以通过阅读一些开源框架的源码来提升自己对设计模式的理解,明确在实战中如何使用设计模式来编写和重构代码。学习设计模式一要耐心、而要思考、三要使用。

二、设计模式

        既然设计模式是一套前辈总结的经验,那这些经验具体都有哪些呢?前辈们根据设计这段代码所实现的功能进行了分类,个人觉得如果了解一些面向对象的思想,可能更容易理解设计模式。        

        以java为例,java中有封装、类、继承、多态、方法等概念,如果我们想使用一个类,就需要创建这个类的对象,在实际开发中创建对象的代码到处都有,重复性高,耦合性高,因此针对于对象的创建,前辈们总结出了一系列创建对象的设计模式(这仅仅是我自己的理解,可能有错误,请指正),也就是第一类设计模式:创建型模式;

        类中会定义多个方法,每个方法都为完成一定的业务功能,有的一些复杂的、使用场景多变的功能可能实现和扩展起来比较困难或者不尽人意,前辈们是很聪明的,针对功能的实现也总结出了一系列设计模式,也就是第二种:行为型模式;

        使用java开发的同学在实际开发中为了解决耦合和复用问题,肯定会使用继承和多态,为了完成一个功能也肯定会有多个类或者对象进行协作,(个人理解)为了更好的实现类或者对象之间的协作和组合,前辈们总结出了一系列关于结构上的设计方法,也就是第三类设计模式:结构型模式。

        这里仅仅从大方向上介绍了设计模式分类和针对解决的场景,不具体分析,总结一下,贴一张图:

 三、设计原则

       除了代码设计的经验,还有一些设计的原则也需要知道。在平时做项目(产品)的过程中,需求变更可能是我们听过的最多概念之一,为了适应变更就需要开发人员频繁调整对应的代码,前辈们建议不要频繁修改已有的业务代码,而应该在软件设计之初就考虑后续如何进行扩展,通过扩展的方式来实现最新的业务需求,这也就是第一个原则:开闭原则,以我自己的理解就是对内封闭,对扩展开放,应尽量想办法通过扩展实现业务,而不是修改原有代码。在开发中,经常会使用继承的开发思想,想一个场景,本来通过A类就可以实现功能,现在为了迎合系统需求变更,需要通过扩展A类来实现,也就是写了一个B类来继承A类,这样在B类中扩展功能,且可以用B来替换任意使用A的场景,这也就是第二个原则:里氏替换原则,到这里可能有同学就会问了,如果B类中覆写了A类中的方法怎么办,答案是不建议覆写,因为覆写就不能完全替换了,这也是里氏替换原则的限制,子类可以对父类进行功能上的扩展,但是不能改变父类原来的功能。开发中的业务层,我们一般的开发方式是开发服务接口,在控制层通过依赖接口实现具体的业务调用,而并不是直接以来具体的业务实现类,其实这就是坚持了第三个原则:依赖倒置原则,其实我不是很清楚为什么叫“依赖倒置”,我觉得叫做“依赖抽象”或者“面向接口编程”可能更容易理解,上层去依赖抽象的接口,可以说简单一点,就是控制层中依赖服务层定义的服务接口,而不是直接去依赖实现类,这样做的好处没必要说的太复杂,举个例子,你女朋友想吃饭,她只需要和你说要吃饭就可以了,至于吃什么、怎么吃、去哪里吃你自己掂量着办,反正是要吃饭。领导让你写一个爬取数据的接口和一个清洗数据的接口,你肯定会分两节接口写,甚至会分成两个类去实现,这就是第四个原则:接口隔离原则,这个不多说,基本都会遵守,如果不遵守这个原则,基本是天天被领导骂。不知道大家之前在没有用框架管理对象时是否遇到过循环依赖的问题,这类问题很讨厌,当时为了解决这类问题,在开发时我们都尽量避免同级不同业务之间的相互调用,这在无形中也遵守了第五个原则:最小知道原则(迪米特原则),开发时尽量避免不同业务之间的代码侵染,也就是不同类之间的频繁关联,可以降低代码耦合性。最后一个原则是:单一职责原则,这个不多说,一个方法只负责一个事情,不要过分的将多个业务写到一个方法中,同样的如果不遵守这个原则,基本是天天被领导骂。总结一下六个设计原则,贴一张图:

 

        这些设计的模式和原则需要融会贯通,它们之间是相辅相成的,其实在平时开发中,我们已经遵守了很多设计的原则,通过使用设计模式和遵守设计原则,会使得我们的代码复用程度更高,代码间高内聚、低耦合,稳定性强、扩展性强。

        以上都是自己根据已有的经验写的一些浅薄的认识,如有纰漏,多多指教。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321395.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P3600-随机数生成器【dp,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/P3600 题目大意 nnn个数的序列,每个数是[1..x][1..x][1..x]中的一个,有qqq个区间[l..r][l..r][l..r],求所有区间最小值的最大值的期望。 解题思路 首先如果一个区间包含别的区间&#xff0…

Visual Studio 15.7预览版4改进Git、C++支持

对于即将到来的Visual Studio 2017 15.7,微软已经发布了多个新的预览版本。这些版本的变更很有限,似乎离正式发布不远了。通常,变更的涉及面很广——因此,不管是用什么语言,开发人员都可以看到一些好处。第一次&#x…

【动态规划】农田个数 (ssl 1633)

农田个数农田个数农田个数 Description 你的老家在河北农村。过年时,你回老家去拜年。你家有一片NM农田,将其看成一个NM的方格矩阵,有些方格是一片水域。你的农村伯伯听说你是学计算机的,给你出了一道题: 他问你…

VB程序逆向常用的函数

转自: http://www.cnblogs.com/bbdxf/p/3780187.html VB程序逆向常用的函数 1) 数据类型转换: a) __vbaI2Str 将一个字符串转为8 位(1个字节)的数值形式(范围在 0 至 255 之间) 或2 个字节的数值形式(范围在 -32,768 到 32,767 之间)。 b)__vbaI4St…

P2827-蚯蚓【队列】

前言 早年一直拿堆过不了,结果发现要用队列 正题 题目链接:https://www.luogu.com.cn/problem/P2827 题目大意 有nnn条蚯蚓,每次选取最长的一条,切成⌊x∗p⌋\lfloor x*p\rfloor⌊x∗p⌋和x−⌊x∗p⌋x-\lfloor x*p\rfloorx−⌊x∗p⌋的两…

.net core DI 注册 Lazy 类型

当我们在 .net core (2.1) 中运行如下代码注入 Lazy<T> 变量的时候&#xff1a;public AccountService(Lazy<IHttpContextAccessor> httpContextAccessor) { }可能会遇到这样的错误提示&#xff1a;InvalidOperationException: Unable to resolve service for type…

操作系统复习笔记 02-03 OS Structure 操作系统结构

02-03操作系统结构&#xff08;OS_Structure&#xff09;[]陈述&#xff1a;1.IO设备与CPU可并行运行。2.每一个设备控制器负责一个设备类型。3.每一个设备控制器有一个局部缓存。4.CPU通过局部缓存与主存交换数据。5.设备控制器通过引起中断通知CPU操作已完成。[]中断机制&…

【深搜】 棋盘 【NOIp普及组 2017 第三题】 (luogu 3956/ssl 2851)

棋盘棋盘棋盘 题目大意&#xff1a; 有一个M*M的棋盘&#xff0c;要从&#xff08;1&#xff0c;1&#xff09;到&#xff08;m,m&#xff09;&#xff0c;中间有n个有颜色的格子&#xff0c;只能踩在有颜色的格子上&#xff0c;跳到不同颜色的格子要花费1元&#xff0c;可以将…

P3332-[ZJOI2013]K大数查询【树套树】

正题 题目链接&#xff1a;https://www.luogu.com.cn/problem/P3332 题目大意 开始nnn个可以重复的集合&#xff0c;要求支持操作 1lrc:1\ l\ r\ c:1 l r c:将ccc加入集合l∼rl\sim rl∼r中2lrk:2\ l\ r\ k:2 l r k:查询l∼rl\sim rl∼r的并集中第kkk大的数 解题思路 此题考…

别跟我谈EF抵抗并发,敢问你到底会不会用EntityFramework

前言一直以来写的博文都是比较温婉型的博文&#xff0c;今天这篇博文算是一篇批判性博文&#xff0c;有问题欢迎探讨&#xff0c;如标题&#xff0c;你到底会不会用EntityFramework啊。你到底会不会用EntityFramework啊面试过三年至六年的同行&#xff0c;作为过面试者到如今作…

操作系统复习笔记 04 Process 进程

[]进程的概念1.进程是操作系统执行的各种程序。2.现在的操作系统多为并发执行&#xff0c;具有许多新的特征。引入并发执行的目的是提高资源利用率。3.OS的基本特征是[并发与共享]。4.顺序环境计算机系统只有一个程序在执行&#xff0c;该程序独占系统的所有资源&#xff0c;其…

【动态规划】 多米诺骨牌 (ssl 1632/luogu 1282)

多米诺骨牌多米诺骨牌多米诺骨牌 Description Input 输入文件的第一行是一个正整数n(1≤n≤1000)&#xff0c;表示多米诺骨牌数。接下来的n行表示n个多米诺骨牌的点数。每行有两个用空格隔开的正整数&#xff0c;表示多米诺骨牌上下方块中的点数a和b&#xff0c;且1≤a&#…

为什么 web 开发人员需要迁移到. NET Core, 并使用 ASP.NET Core MVC 构建 web 和 API

2018 .NET开发者调查报告: .NET Core 是怎么样的状态&#xff0c;这里我们看到了还有非常多的.net开发人员还在观望&#xff0c;本文给大家一个建议。这仅代表我的个人意见, 我有充分的理由推荐.net 程序员使用. net core而不是. net Framework。有些人可能不同意我的观点, 但是…

CF1260C-Infinite Fence【结论题】

正题 题目链接:https://www.luogu.com.cn/problem/CF1260C 题目大意 无数个栏杆&#xff0c;rrr的倍数染成红色&#xff0c;bbb的倍数染成蓝色&#xff0c;是rrr和bbb的倍数的话可以选择一个染色&#xff0c;去掉没有染色的&#xff0c;是否有一种方案使得最长的染色快不超过…

【动态规划】 摆花 【NOIp普及组 2012 第三题】 (ssl 2360/luogu 1077)

摆花摆花摆花 题目大意 有n种花&#xff0c;每种花有ai支&#xff0c;取m支&#xff0c;有多少种取法&#xff1f;&#xff08;同一种花取第1&#xff0c;第3支和取第1&#xff0c;第2支算一种取法&#xff09; 解题方法&#xff1a; 用f[i][j]来表示前i种选j支的方案数&…

操作系统复习笔记 05 Thread 线程

进程的两个基本属性1.拥有资源的独立单位2.可独立调度和分派的基本单位进程的数目不宜过多&#xff0c;进程切换频率不宜过高&#xff0c;限制了并发程度。操作系统的设计目标是&#xff1a;提高并发度、减小系统开销。引入线程的目的是简化线程间的通信&#xff0c;以小的开销…

使用SonarCloud对.NET Core项目进行静态代码分析

本文将介绍如何使用SonarCloud进行.NET Core项目的静态代码分析。SonarCloud是SonarQube提供的基于云的版本&#xff0c;特别针对于开源项目是免费的。首先&#xff0c;在sonarcloud.io创建一个账号&#xff0c;你可以使用Github/BitBucket/Microsoft Live账户进行注册&#xf…

P6477-[NOI Online #2 提高组]子序列问题【线段树】

正题 题目链接:https://www.luogu.com.cn/problem/P6477 话说这是luogu的冥间数据 题目大意 nnn个数的序列&#xff0c;f(l,r)f(l,r)f(l,r)表示l∼rl\sim rl∼r有多少个不同的数字。 求∑l1n∑rln(f(l,r))2\sum_{l1}^n\sum_{rl}^n(f(l,r))^2l1∑n​rl∑n​(f(l,r))2 解题思路…

操作系统复习笔记 06 CPU Scheduling CPU调度

CPU的三级调度&#xff1a;1.高级调度(Long-term)&#xff1a;作业调度&#xff0c;从外存进内存2.低级调度(Short-term)&#xff1a;进程调度&#xff0c;分配处理机3.中级调度(Medium-term)&#xff1a;对换通过多道程序设计得到CPU的最高使用率。CPU-IO脉冲周期&#xff1a;…

【动态规划】 石子合并问题(环形) (ssl 1597)

石子合并问题石子合并问题石子合并问题 Description 在一个圆形操场的四周摆放着n 堆石子。现要将石子有次序地合并成一堆。规定每次只能选相邻的2 堆石子合并成新的一堆&#xff0c;并将新的一堆石子数记为该次合并的得分。试设计一个算法&#xff0c;计算出将n堆石子合并成…