设计模式概述

简介: 设计模式概述

简单工厂模式

工厂模式有一种非常形象的描述,建立对象的类就如一个工厂,而需要被建立的对象就是一个个产品;在工厂中加工产品,使用产品的人,不用在乎产品是如何生产出来的。从软件开发的角度来说,这样就有效的降低了模块之间的耦合。

就如同写一个计算器,我们只需要为每个运算符添加指定的处理逻辑,然后再需要时实例化指定的操作符,进行解耦处理,防止在一个运算类中添加过多的代码,造成过耦合

class OperationAdd:Operation
{
....
}
class OperationSub:Operation
{
....
}
....
public class OperationFactorty
{
    public static Operation createOperate(string operate)
    {
        Opertaion oper = null ;
        switch(operate){
            case "+":
                oper=new OperationAddd();
            case "-":
                oper=new OperationSub();
            ......      
        }
    }
}
# 策略模式
**策略模式**:它定义了算法家族,分别封装起来,让他们之间可以互相转换,减少了各种算法类与使用算法类之间的耦合,此模式让算法发生变化,不会影响到使用算法的用户.
此外,策略模式简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口进行单独测试.
![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/ca2e758d416d4211b1cddf6bacc5fd8c.png#pic_center)
```java
//抽象类算法
abstract class Strategy
{
    //算法方法
    public override void  AlgorithmInterface();
}
// 具体算法B
class ConcreteStrategyA:Strategy
{
    //算法B实现方法
    public override void  AlgorithmInterface();
}
class ConcreteStrategyC:Strategy
{
    //算法B实现方法
    public override void  AlgorithmInterface();
}
// Context,用一个ConcreteStrategy来配置,维护对一个Strategy对象的引用
class Context
{
    Strategy strategy;
    // 初始化,传入具体的策略对象
    public Context(Strategy strategy){
        this.strategy=strategy;
    }
    // 上下文接口,根据具体的策略对象,调用相应的算法
    public void ContextInterface()
    {
        strategy. AlgorithmInterface();
    }
}

单一职责原则

单一职责原则:就一个类而言,应该仅有一个引起它变化的原因。

如果一个类承担的责任过多,就等于把这些职责耦合在一起,一个职责的变化可能削弱或者抑制这个类完成其他职责的能力。这种耦合会导致脆弱的设计,发生变化时,设计会遭受意想不到的破坏。

开放-封闭原则

开放-封闭原则:软件实体(类,模块,函数等等)是可以扩展的,但是不可修改。

无论模块是多么 的封闭,都会存在一些无法对之封闭的目录,既然不可能完全封闭,设计人员必须对于他设计的模块应该对哪种变化封闭做出选择。他必须先猜测出最有可能发生变化的种类,然后用抽象隔离那些变化。

在我们编写程序时,假设变化不会发生,当变化发生时,我们就创建抽象来隔离以后发生的同类变化。

依赖倒转原则

依赖倒转:可以说是面向对象设计的标志,用那种语言来编写程序并不重要,如果编写时考虑的如何针对抽象编程而不是针对细节编程,即程序中所有依赖关系都是终止抽象类或接口,那就是面向对象的设计,反之就是过程化的设计。

里氏代换原则:子类必须能够替换掉它们的符类型。

装饰模式

装饰模式:动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活。

装饰类的核心就是把类的核心职责和装饰功能区分开,而且可以去除相关的类中的重复的装饰逻辑。

代理模式

代理模式为其他对象提供一种代理控制对这个对象访问。

远程代理:也就是为一个对象在不同的地址空间提供局部代表。这样可以隐藏对象在于不同地址空间的事实。

虚拟代理:根据需要创建开销很大的对象,通过他来存放实例化需要很长时间的真实对象。

安全代理:用来控制真实对象访问时的权限。

智能指引 :指当调用真实的对象,代理处理另外一些事。


相关文章
|
设计模式 算法 程序员
设计模式的概述及各个模式的功能介绍
设计模式的概述及各个模式的功能介绍
136 0
|
2月前
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
创建型模式的主要关注点是“怎样创建对象?”,它的主要特点是"将对象的创建与使用分离”。这样可以降低系统的耦合度,使用者不需要关注对象的创建细节。创建型模式分为5种:单例模式、工厂方法模式抽象工厂式、原型模式、建造者模式。
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
|
2月前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
|
2月前
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
结构型模式描述如何将类或对象按某种布局组成更大的结构。它分为类结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者釆用组合或聚合来组合对象。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象结构型模式比类结构型模式具有更大的灵活性。 结构型模式分为以下 7 种: • 代理模式 • 适配器模式 • 装饰者模式 • 桥接模式 • 外观模式 • 组合模式 • 享元模式
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
|
2月前
|
设计模式 Java 程序员
【23种设计模式·全精解析 | 概述篇】设计模式概述、UML图、软件设计原则
本系列文章聚焦于面向对象软件设计中的设计模式,旨在帮助开发人员掌握23种经典设计模式及其应用。内容分为三大部分:第一部分介绍设计模式的概念、UML图和软件设计原则;第二部分详细讲解创建型、结构型和行为型模式,并配以代码示例;第三部分通过自定义Spring的IOC功能综合案例,展示如何将常用设计模式应用于实际项目中。通过学习这些内容,读者可以提升编程能力,提高代码的可维护性和复用性。
【23种设计模式·全精解析 | 概述篇】设计模式概述、UML图、软件设计原则
|
2月前
|
设计模式 算法 搜索推荐
设计模式概述
设计模式是软件工程中的最佳实践,帮助开发者解决常见问题,提高代码的可重用性、可读性和可靠性。学习设计模式可以提升思维能力、标准化程序设计、增强代码质量。文章介绍了设计模式的分类(创建型、结构型、行为型)及其在流行框架中的应用,建议读者掌握SOLID原则并深入学习GoF的23种设计模式。
96 3
设计模式概述
|
9月前
|
设计模式 数据可视化 测试技术
设计模式概述
设计模式概述
设计模式概述
|
7月前
|
设计模式 Java 开发者
设计模式概述
设计模式概述
|
8月前
|
设计模式 算法 Java
Java设计模式:核心概述(一)
Java设计模式:核心概述(一)
|
9月前
|
设计模式 缓存 算法
设计模式概述
设计模式概述
74 0

热门文章

最新文章