【软考七】面向对象技术--UML、设计模式(分数重,刷题刷题)

news2025/1/24 4:41:48

建议UML和设计模式去听听课,内容多,还需要记。这一部分内容较多,下半年的考生可以慢慢看,上半年的就去刷题吧。
该博客不适合学习UML和设计模式,只适合考试。要学的不要在这浪费时间,切记切记
在5月13号忽然发现时间已经不多了,博客就先这样,先去刷题了,以后会补回来。抱歉抱歉

一、面向对象基础

面向过程和面向对象

面向过程:就像人。
面向对象:就像会魔法的魔仙。

例子

比如:刷碗这个动作。
面向过程(人):人将碗从桌子上拿到水池,拧开水龙头,用百洁布擦拭,倒入洗洁精,冲水,看到干净了就OK了
面向对象(魔仙):用魔法棒控制,碗从桌子上飞到水池中,水龙头拧开,百洁布自动擦拭,洗洁精飞起倒入,碗感觉自己干净了就OK了。

其中包含的对象和对象的方法
碗: 飞起、落地、检查自身状态
水龙头:关闭、打开
百洁布:擦拭
洗洁精:飞起、倾倒

开发人员调用碗、水龙头、百洁布、洗洁精的方法实现刷碗这个动作。

(一)基本概念

面向对象 = 对象+分类+继承+通过消息的通信

1、类

类是对象的抽象

(1) 类别
  1. 实体类:实体类的对象表示现实世界中真实的实体
  2. 接口类(边界类):接口类的对象为用户提供一种与系统合作交互的方式,分为人和系统两种。
  3. 控制类:控制活动流,充当协调者

2、对象

对象名、属性和方法三个部分组成。
是类的实例,既包括数据(属性或状态或成员变量),也包括作用于数据的操作(行为或方法或函数或成员函数)

3、消息

对象间进行通信的一种构造 。当一个消息发送给某个对象时,包含要求对象去执行某些活动的信息。接收到信息的对象经过解释,然后予以响应。这种通信机制叫做消息传递

4、方法重载(也叫操作、行为、函数)

  • 同一个方法名,参数名不同
  • 同一个方法名,参数类型不同
  • 同一个方法名,参数顺序不同

5、三大特征

封装、继承、多态

(1)封装

封装是一种信息隐藏技术,实现对象的使用者和生产者分离。
对象是封装数据和行为的整体

数据和行为可声明为private(私有)和public(共有),声明为private的方法或属性只能在当前类中定义的方法中被访问到。
关键字this可以用于区分同名的对象属性和局部变量名。

(2)继承

父类、超类、基类
子类、派生类
父类和子类共享数据和方法的机制。子类是父类的特例,一个父类可以有多个子类,父类已有的非私有化属性和方法在子类中不必定义,可直接使用,子类可有自己的属性和方法。同一个方法名可在子类中被重写(覆盖),也就相当于方法重载。
单重继承:子类只继承一个父类
多重继承:子类继承多个父类,可能造成子类中出现二义性的成员

(3)多态

收到消息时,对象要予以响应。不同对象收到同一消息可以完全产生不同的结果,这一现象称为多态,由继承机制来支持,实现细节由接收对象自行决定。动态绑定是实现多态的基础

Person gll = new Student();
编译:编译时gll类为Person
运行:运行时gll类为Student

多态的不同形式(考的多)
多态的形式

6、动态绑定、静态绑定

绑定是一个把过程调用和响应调用所需要执行的代码加以结合的过程。一般的程序设计语言中,编译时进行静态绑定,运行时进行动态绑定。一个给定的过程调用和代码的结合直到调用发生时才进行

(二)面向对象分析(按顺序的,背)–OOA

在这里插入图片描述

(三)面向对象设计 – OOD

目标:定义系统的构造蓝图。理解解决方案,实现系统

1、面向对象设计的原则 (常考,背)

在这里插入图片描述

2、面向对象设计的活动

在这里插入图片描述

(四)面向对象程序设计

程序设计语言相关,下午题中记录

(五)面向对象测试

在这里插入图片描述

(六)其他知识点

  1. 静态方法只能访问同一类中的静态数据成员
  2. 静态数据成员可被同一类中的所有方法访问
  3. 同一类的对象共享静态数据成员的值。
  4. 静态数据成员的值可修改
  5. 面向对象技术中,对象拥有清晰的边界、良好的定义行为和可扩展性三个特性
  6. 领域类模型包含属性、操作、关联

二、UML(上午题3~5分,下午题15分)

UML(统一建模语言),构造块包含事物、关系、图。事物是对模型中最具有代表性的成分的抽象;关系把事物结合在一起;图聚集了相关事物。

(一)事物

在这里插入图片描述
各结构事物的图形化
在这里插入图片描述
各行为事物的图形表示
在这里插入图片描述
包和注解的图形表示
在这里插入图片描述

(二)关系

在这里插入图片描述

依赖关系图示
在这里插入图片描述
关联关系、聚合关系、组合关系图示
两个类之间可以有多个由不同角色标识的关联。
关联的多重度(重复度)指:一个类的实例能够被另一个类的多少实例相关联
关联关系可不标注多重度和角色,若为实线单向箭头,则表示是单向关联(类似依赖,但是比依赖的强度要强。人依赖于食物活着,但不是时时刻刻需要;鱼单向关联水,需要时时刻刻在水中)。
下面关联代表的意思是:一个雇主对应0个或多个雇员,一个雇员对应0个或一个雇主。

当两个类关联,A类的实例重复关联B类的实例时,衍生出一个属性,放在这两个类中都不妥时,就定义一个关联类
在这里插入图片描述
泛化关系图示
在这里插入图片描述
实现关系图示
在这里插入图片描述

(三)图

图:一组元素的图形表示,大多数情况下把图画成顶点(代表事物)和弧(代表关系)的连通图。

1、图的分类

在这里插入图片描述

(1) 类图补充

在这里插入图片描述


在这里插入图片描述
在这里插入图片描述

(2) 对象图补充(下午没考过)

在这里插入图片描述

对象
在这里插入图片描述
在这里插入图片描述

(3) 用例图补充(下午题常考,加油)

在这里插入图片描述

在这里插入图片描述

(4)交互图介绍

用于对系统的动态方面进行建模。一张交互图表现的是一个交互,由一组对象和他们之间的关系组成,包含传递的消息。包含序列图、通信图、交互概览图和计时图。序列图是强调消息时间顺序的交互图;通信图是强调接收和发送消息的对象的结构组织的交互图。一般包含对象、链和消息。

(5)序列图(也叫顺序图)

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(6)通信图(协作图)

在这里插入图片描述
路径这一特点未在图中表现出来
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(7)状态图(常考)

在这里插入图片描述

组合状态

由状态、活动、转换、事件组成,分别介绍
状态和活动
在这里插入图片描述

状态
在这里插入图片描述
在这里插入图片描述
转换和事件
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

(8)活动图(不常考)

状态图:从一个状态到另一个状态
活动图:从一个活动到另一个活动
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

(9)构件图(不常考)

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

(10)部署图(不常考)

在这里插入图片描述

在这里插入图片描述

2、图总结

在这里插入图片描述
在这里插入图片描述

UML构造块组织结构图附件

附件地址

附件中是UML部分的全部结构图,本人使用的工具是 XMIND 。

三、设计模式

在这里插入图片描述

(一) 创建型模式设计

在这里插入图片描述

简单工厂模式(引入,便于后续,不在23种设计模式之内)

在这里插入图片描述
在这里插入图片描述

/**
 * 简单工厂模式。以在饺子馆买饺子为例
 */
// main方法
public class SimpleFactory {
    public static void main(String[] args) {
        Product A = Factory.createProduct("A");
        A.info();

        Product B = Factory.createProduct("B");
        B.info();

        Product C = Factory.createProduct("C");
        C.info();
    }
}

// 工厂类,可直接被外界访问。该类相当于饺子馆,type为客户需求的饺子馅
class Factory {
    public static Product createProduct(String type) {
        Product product = null;
        switch(type) {
            case "A":
              product = new ProductA();
              break;
            case "B":
                product = new ProductB();
                break;
            default:
                System.out.println("产品生产完成");
                break;
        }
        return product;
    }
}

// 抽象的产品类,不可被实例化,为父类。相当于饺子,但不知道是什么馅
abstract class Product {
    public abstract void info();
}

// 具体的产品类,为子类。相当于韭菜馅饺子,是一个确定的个体了
class ProductA extends Product {
    @Override
    public void info() {
        System.out.println("此为A产品");
    }
}

// 具体的产品类,为子类。相当于猪肉大葱馅饺子,是一个确定的个体了
class ProductB extends Product {
    @Override
    public void info() {
        System.out.println("此为B产品");
    }
}

1、类模式

(1) 工厂方法模式(一个工厂只能创建一类产品)

在这里插入图片描述

在这里插入图片描述

/**
 * 工厂方法模式。以手机零件生产工厂为例
 */
public class FactoryMethod {
    public static void main(String[] args) {
        Factory1A factory1A = new Factory1A();
        Product1 product1A = factory1A.createProduct();
        product1A.info();

        Factory1B factory1B = new Factory1B();
        Product1 product1B = factory1B.createProduct();
        product1B.info();
    }
}

/**
 * 工厂类
 */
// 工厂父类。相当于工厂的管理部门,只知道要生产零件
interface Factory1 {
    public Product1 createProduct();
}

// 工厂子类。相当于手机屏生产车间,明确知道自己的工作,且只做这份工作,不接受外来消息的影响
class Factory1A implements Factory1 {
    @Override
    public Product1 createProduct() {
     return new Product1A();
    }
}

// 工厂子类。相当于充电器生产车间,明确知道自己的工作,且只做这份工作,不接受外来消息的影响
class Factory1B implements Factory1 {
    @Override
    public Product1 createProduct() {
        return new Product1B();
    }
}

// 产品父类。相当于手机
interface Product1 {
    public void info();
}

// 产品子类,相当于手机屏,明确知道自己是什么零件
class Product1A implements Product1 {
    @Override
    public void info() {
        System.out.println("此为工厂方法的A产品");
    }
}

// 产品子类,相当于充电器,明确知道自己是什么零件
class Product1B implements Product1 {
    @Override
    public void info() {
        System.out.println("此为工厂方法的B产品");
    }
}

2、对象模式

(1) 抽象工厂模式(一个工厂只能创建多类产品)

在这里插入图片描述

在这里插入图片描述

/**
 * 抽象工厂模式
 */
public class AbstractFactory {
    public static void main(String[] args) {
        // 创建工厂子类A实例
        ConcreateFactoryA concreateFactoryA = new ConcreateFactoryA();
        AbstractProductA abstractProductA1 = concreateFactoryA.createAbstractProductA();
        abstractProductA1.info();
        AbstractProductB abstractProductB1 = concreateFactoryA.createAbstractProductB();
        abstractProductB1.info();
        // 创建工厂子类B实例
        ConcreateFactoryB concreateFactoryB = new ConcreateFactoryB();
        AbstractProductA abstractProductA2 = concreateFactoryB.createAbstractProductA();
        abstractProductA2.info();
        AbstractProductB abstractProductB2 = concreateFactoryB.createAbstractProductB();
        abstractProductB2.info();
    }
}

// 工厂父类
interface FactoryAbstract {
    public AbstractProductA createAbstractProductA();
    public AbstractProductB createAbstractProductB();
}

// 具体的工厂,工厂子类A,可生产两类产品,且这两类不相关
class ConcreateFactoryA implements FactoryAbstract {
    @Override
    public AbstractProductA createAbstractProductA() {
        return new ProductA1();
    }
    @Override
    public AbstractProductB createAbstractProductB() {
        return new ProductB1();
    }
}

// 具体的工厂,工厂子类B,可生产两类产品,且这两类不相关
class ConcreateFactoryB implements FactoryAbstract {
    @Override
    public AbstractProductA createAbstractProductA() {
        return new ProductA2();
    }
    @Override
    public AbstractProductB createAbstractProductB() {
        return new ProductB2();
    }
}

// 产品父类A
interface AbstractProductA {
    public void info();
}

// 产品父类A的子类
class ProductA1 implements AbstractProductA {
    @Override
    public void info() {
        System.out.println("此为ProductA1");
    }
}

// 产品父类A的子类
class ProductA2 implements AbstractProductA {
    @Override
    public void info() {
        System.out.println("此为ProductA2");
    }
}

// 产品父类B
interface AbstractProductB {
    public void info();
}

// 产品父类B的子类
class ProductB1 implements AbstractProductB {
    @Override
    public void info() {
        System.out.println("此为ProductB1");
    }
}

// 产品父类B的子类
class ProductB2 implements AbstractProductB {
    @Override
    public void info() {
        System.out.println("此为ProductB2");
    }
}
(2) 生成器模式

在这里插入图片描述

在这里插入图片描述

/**
 * 生成器模式。以卖手机为例,有各种套餐
 */
public class BuilderMode {
    public static void main(String[] args) {
        Director director = new Director();
        Builder1 builder1 = new Builder1();
        director.Construct(builder1);
        ProductBuilder product1 = builder1.getResult();
        product1.show();

        Builder2 builder2 = new Builder2();
        director.Construct(builder2);
        ProductBuilder product2 = builder2.getResult();
        product2.show();
    }
}

// 相当于客户,指定需要哪种套餐
class Director {
    public void Construct(Builder builder) {
        builder.BuildPart();
    }
}

// 生成器父类。相当于手机套餐配送前的装箱小组
abstract class Builder {
    public abstract void BuildPart();
    public abstract ProductBuilder getResult();
}

// 生成器子类。相当于装箱小组中的成员1
class Builder1 extends Builder {
    // 此时为还不知道套餐是什么的产品
    ProductBuilder product = new ProductBuilder();

    @Override
    public void BuildPart() {
        product.Add("手机");
        product.Add("充电头");
        product.Add("充电线");
    }

    @Override
    public ProductBuilder getResult() {
        return product;
    }
}

// 生成器子类。相当于装箱小组中的成员2
class Builder2 extends Builder {
    // 此时为还不知道套餐是什么的产品
    ProductBuilder product = new ProductBuilder();

    @Override
    public void BuildPart() {
        product.Add("手机");
        product.Add("手环");
        product.Add("耳机");
    }

    @Override
    public ProductBuilder getResult() {
        return product;
    }
}

// 产品。相当于手机产品,里面有套餐数组
class ProductBuilder {
    List<String> parts = new ArrayList<String>();  // 手机部件
    // 向套餐中添加配件
    public void Add(String part) {
        parts.add(part);
    }

    public void show() {
        System.out.println("产品包含:");
        for (String part:parts
             ) {
            System.out.println(part+",");
        }
        System.out.println("\n");
    }
}
(3) 原型模式

在这里插入图片描述
在这里插入图片描述

/**
 * 原型模式
 */
public class PrototypeMode {
    public static void main(String[] args) {
        ProductPrototype product1 = new ProductPrototype(2023, 5.28);
        System.out.println(product1.getId()+"/"+product1.getPrice());

        ProductPrototype product2 = product1.Clone();
        System.out.println(product2.getId()+"/"+product2.getPrice());
    }
}

// 类原型父类
interface Prototype {
    public Object Clone();
}

// 类原型子类,意思是直接复制这个类创建的一个实例
class ProductPrototype implements Prototype {
    private  int id;
    private double price;

    // 构造函数
    public ProductPrototype() {}
    public ProductPrototype(int id,double price) {
        this.id = id;
        this.price = price;
    }

    public int getId() {
        return id;
    }
    public double getPrice() {
        return price;
    }

    @Override
    public ProductPrototype Clone() {
        ProductPrototype productPrototype = new ProductPrototype();
        productPrototype.id = this.id;
        productPrototype.price = this.price;
        return productPrototype;
    }
}
(4) 单例模式

在这里插入图片描述
在这里插入图片描述

/**
 * 单例模式
 */
public class SingletonPattern {
    public static void main(String[] args) {
//        Singleton singleton1 = new Singleton();  // 这样会报错
        // 下面的其实都是一个实例
        Singleton instance1 = Singleton.getInstance();
        Singleton instance2 = Singleton.getInstance();
        Singleton instance3 = Singleton.getInstance();
        System.out.println(instance1.getNumber()+"/"+instance2.getNumber()+"/"+instance3.getNumber());

        instance1.setNumber(22222);
        System.out.println(instance1.getNumber()+"/"+instance2.getNumber()+"/"+instance3.getNumber());
    }
}

class Singleton {
    private int number = 2023;
    public void setNumber(int number) {
        this.number = number;
    }
    public int getNumber() {
        return number;
    }

    private Singleton(){}  // 设为私有,可保证只能通过全局访问点访问唯一的实例
    private static Singleton instance =  new Singleton();
    public static Singleton getInstance(){
        return instance;
    }
}

在这里插入图片描述

(二) 结构型模式设计

1、类模式

(1) 适配器模式(不常考,可不看)

在这里插入图片描述

在这里插入图片描述

2、对象模式

(1) 适配器模式(一般考对象适配器模式)

在这里插入图片描述

在这里插入图片描述

/**
 * 适配器模式。相当于转接头,此处以typec接口转USB接口为例
 */
public class AdapterPattern {
    public static void main(String[] args) {
        Target target = new Adapter();
        target.Request();
    }
}
// 最终需要的类。相当于USB口
class Target {
    public void Request() {
        System.out.println("我是目标类");
    }
}

// 适配转换的类。相当于转接头,披着羊皮的狼。我外表是目标类,实际内心是现有的不匹配的类
class Adapter extends Target {
    private Adaptee adaptee = new Adaptee();
    @Override
    public void Request() {
        adaptee.specificRequest();
    }
}

// 现有的类。与需要的类不同。相当于Typec接口
class Adaptee {
    public void specificRequest() {
        System.out.println("我是特殊的,需要转换一下的类");
    }
}
(2) 桥接模式

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

/**
 * 桥接模式。理解的意思就像是生产手机,可生产的机型可以有多种,手机的颜色可以有多种上色选择。
 * 任意一种机型可以上各种不同的颜色。就是将两个都可实现的方法任意组合起来
 */
public class BridgePattern {
    public static void main(String[] args) {
        Abstraction abstractionA1 = new AbstractionA();
        Abstraction abstractionA2 = new AbstractionA();
        Implementor implementor1 = new Implementor1();
        Implementor implementor2 = new Implementor2();
        
        abstractionA1.setName("iphone 12");
        abstractionA1.setImplementor(implementor1);
        abstractionA1.Operation();
        
        abstractionA2.setName("iphone 13");
        abstractionA2.setImplementor(implementor2);
        abstractionA2.Operation();
    }
}

// 抽象父类
abstract class Abstraction {
    private String name;
    protected  Implementor implementor;
    public void setName(String name) {
        this.name = name;
    }
    public String getName() {
        return name;
    }

    public void setImplementor(Implementor implementor) {
        this.implementor = implementor;
    }

    public abstract void Operation();
}

// 抽象子类。使用implementor类实现最终的操作
class AbstractionA extends Abstraction {
    @Override
    public void Operation() {
        implementor.OperationImp(this.getName());
    }
}

// 实现类接口父类
interface Implementor {
    public void OperationImp(String name);
}

// 实现类接口子类
class Implementor1 implements Implementor {

    @Override
    public void OperationImp(String name) {
        System.out.println(name+":涂为乳白色");
    }
}

// 实现类接口子类
class Implementor2 implements Implementor {

    @Override
    public void OperationImp(String name) {
        System.out.println(name+":涂为天蓝色");
    }
}
(3) 组合模式

在这里插入图片描述

在这里插入图片描述

/**
 * 组合模式,以树形结构展示部分-整体。此处以文件夹中包含文件、文件夹为例
 */
public class CompositePattern {
    public static void main(String[] args) {
        Component root = new Composite("root");
        Component folderA = new Composite("folderA");
        Component fileA = new Leaf("fileA");

        Component folderB = new Composite("folderB");
        Component fileB = new Leaf("fileB");

        Component fileC = new Leaf("fileC");
        Component fileD = new Leaf("fileD");
        
        root.Add(folderA);
        root.Add(fileA);
        root.Add(folderB);
        folderA.Add(fileB);
        folderA.Add(fileC);
        folderB.Add(fileD);
        print(root);

    }

    // 该方法可打印某节点的所有儿子、孙子、重孙....后代们
    static void print(Component com) {
        com.printName();

        List<Component> childrenList = com.getChildren();
        if(childrenList == null) return;
        for (Component children: childrenList
             ) {
            // 递归
            print(children);
        }
    }
}

// 父类
abstract class  Component {
    protected String name;

    // 可打印当前结点的名称
    public void printName() {
        System.out.println(name);
    };

    public abstract boolean Add(Component com);  // 此处的参数设为父类,可保证叶子结点和非叶子节点中都可正常使用
    // 对应意图中的 “Composite使得用户对单个对象和组合对象的使用具有一致性”
    public abstract boolean Remove(Component com);

    public abstract List<Component> getChildren();
}

// 子类叶子结点。相当于文件,文件中不可再有文件或文件夹
class Leaf extends Component {
    public Leaf(String name) {
        this.name = name;
    }

    // 叶子结点不能有儿子了,所以直接在添加子节点的时候返回了false
    @Override
    public boolean Add(Component com) {
        return false;
    }

    @Override
    public boolean Remove(Component com) {
        return false;
    }

    @Override
    public List<Component> getChildren() {
        return null;
    }
}

// 子类可有子节点的节点。相当于文件夹,文件夹中还可添加文件或者文件夹
class Composite extends Component {
    // 因为有多个儿子,所以此处用一个list来保存所有的儿子.
    // 此处使用Component,是与上面方法的定义呼应的
    List<Component> childrenList = new ArrayList<Component>();

    public Composite(String name) {
        this.name = name;
    }

    @Override
    public boolean Add(Component com) {
        return childrenList.add(com);
    }

    @Override
    public boolean Remove(Component com) {
        return childrenList.remove(com);
    }

    @Override
    public List<Component> getChildren() {
        return childrenList;
    }
}
(4) 装饰器模式

在这里插入图片描述

在这里插入图片描述

/**
 * 装饰器模式。在已有的基础上给你增加工作量
 */
public class DecoratorPattern {
    public static void main(String[] args) {
        ComponentDecorator you = new ConcreteComponent("老黄牛");
        you.Operation();  // 本身已有的职责

        // 添加职责
        you = new DecoratorA(you);  // 因为大boss都是ComponentDecorator,所有直接用you来接收,这样操作的就都是老黄牛
        you.Operation();
    }
}

// 父类,大boss,其他类都是它的儿子或孙子
abstract class ComponentDecorator {
    protected String name;
    public abstract void Operation();
}

// 子类,作用是保存已有的职责
class ConcreteComponent extends ComponentDecorator {
    public ConcreteComponent(String name) {
        this.name = name;
    }

    @Override
    public void Operation() {
        System.out.println(name+"的职责:写一个列表页面");
    }
}

// 装饰器。其实就是为你添加工作量的领导,具体领导是谁还不确定
abstract class Decorator extends ComponentDecorator {
    protected ComponentDecorator componentDecorator;
}

// 装饰器子类。给你添加工作量的领导之一,可以有千千万万个这样的领导
class DecoratorA extends Decorator {
    public DecoratorA(ComponentDecorator componentDecorator) {
        this.componentDecorator = componentDecorator;
    }

    @Override
    public void Operation() {
        componentDecorator.Operation(); // 已有的职责
        System.out.println("为其添加职责 ");
    }
}
(5) 外观模式

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

/**
 * 外观模式。相当于一个大工厂,工厂的管理人员知道哪个部门生产什么部件
 */
public class FacadePattern {
    public static void main(String[] args) {
        Facade facade = new Facade();
        facade.Method1();
        facade.Method2();
        facade.Method3();
    }
}

// 工厂对外的大门
class Facade {
    SubsystemA subsystemA;
    SubsystemB subsystemB;
    SubsystemC subsystemC;

    public Facade() {
        subsystemA = new SubsystemA();
        subsystemB = new SubsystemB();
        subsystemC = new SubsystemC();
    }

    public void Method1() {
        subsystemA.MethodA();
    }
    public void Method2() {
        subsystemB.MethodB();
    }
    public void Method3() {
        subsystemC.MethodC();
    }
}

// 子系统。工厂内部部门
class SubsystemA {
    public void MethodA() {
        System.out.println("子系统A的方法");
    }
}

// 子系统。工厂内部部门
class SubsystemB {
    public void MethodB() {
        System.out.println("子系统B的方法");
    }
}

// 子系统。工厂内部部门
class SubsystemC {
    public void MethodC() {
        System.out.println("子系统C的方法");
    }
}
(6) 享元模式

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

/**
 * 享元模式。已有多个白色石块了,但是客户要彩色的,无需再次生产,直接将石块喷上各种颜色的漆就可以。
 * 内部状态:石块大小、石块位置
 * 外部状态:石块颜色
 *
 * 此处以圆形包含各种颜色的为例
 */
public class FlyweightPattern {
    public static void main(String[] args) {
        FlyweightFactory flyweightFactory = new FlyweightFactory();

        Random random = new Random();
        String[] colors = {"red","green","blue","pink","black"};
        for (int i = 0; i < 20; i++) {
            int x = random.nextInt(colors.length);   // 区间是[0,5)
            Flyweight flyweight = flyweightFactory.getFlyweight(colors[x]);
            System.out.println("第"+i+"个圆");
            flyweight.draw(random.nextInt(2222), random.nextInt(3333) );
        }
    }
}

// 享元工厂。保存各种对象的仓库
class FlyweightFactory {
    private Map<String,Flyweight> map = new HashMap<String,Flyweight>();  // 用map来保存颜色以及圆本身

    // map里面已有了红色的圆之后,就不再生成了,直接返回;否则,生成保存到map中再返回
    public Flyweight getFlyweight(String key) {
        if(!map.containsKey(key)) {
            Flyweight concreteFlyweight = new ConcreteFlyweight(key);
            map.put(key,concreteFlyweight);
            System.out.println("创建了一个"+key+"色的圆");
        }
        return map.get(key);
    }
}

//享元父类
abstract class Flyweight {
    protected String color;
    public abstract void draw(int x,int y);  // 画圆,标明位置
}

// 享元子类。具体的享元
class ConcreteFlyweight extends Flyweight {
    public ConcreteFlyweight(String color){
        this.color = color;
    }

    @Override
    public void draw(int x, int y) {
        System.out.println("画一个颜色为"+color+"的圆,位置是x: "+x+" y: "+y);
    }
}
(7) 代理模式

在这里插入图片描述
在这里插入图片描述

/**
 * 代理模式。例如代购、律师。此处以代购为例
 */
public class ProxyPattern {
    public static void main(String[] args) {
        RealSubject realSubject = new RealSubject();
        Proxy proxy = new Proxy(realSubject);
        proxy.buy();
    }
}

interface Subject {
    public void buy();
}

class Proxy implements Subject {
    public RealSubject realSubject;

    public Proxy(RealSubject realSubject){
        this.realSubject = realSubject;
    }

    @Override
    public void buy() {
        System.out.println("找到商品");
        System.out.println("讨价还价");
        realSubject.buy();  // 实际的买主付钱
    }
}

class RealSubject implements Subject {
    @Override
    public void buy() {
        System.out.println("付款");
    }
}

在这里插入图片描述

(三) 行为模式设计

1、类模式

(1) 解释器模式

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

/**
 * 解释器模式。说实话,没听太懂,不理解什么情境下能用到。感觉作用就是做了个判断
 */
public class InterpreterPattern {
    public static void main(String[] args) {
        Context context = new Context();

        context.check("朝阳区的开发人员");
        context.check("昌平区的测试人员");
        context.check("东城区的闲散人员");
    }
}

class Context {
    private String[] regions = {"朝阳区","东城区","西城区","丰台区"};
    private String[] persons = {"开发人员","测试人员","行政人员","审计人员"};

    private NonterminalExpression nonterminalExpression;
    public Context() {
        TerminalExpression region = new TerminalExpression(regions);
        TerminalExpression person = new TerminalExpression(persons);
        nonterminalExpression = new NonterminalExpression(region,person);
    }

    public void check(String info) {
        boolean bool = nonterminalExpression.Interprete(info);
        if(bool) {
            System.out.println("识别成功");
        }else {
            System.out.println("识别失败");
        }
    }
}

interface Expression {
    public boolean Interprete(String info);
}


class NonterminalExpression implements Expression {
    private TerminalExpression region;
    private TerminalExpression person;

    public NonterminalExpression(TerminalExpression region,TerminalExpression person) {
        this.region = region;
        this.person = person;
    }

    @Override
    public boolean Interprete(String info) {
        String[] str = info.split("的");
        return region.Interprete(str[0]) && person.Interprete(str[1]);
    }
}

class TerminalExpression implements Expression {
    private Set<String> set = new HashSet<>();
    public TerminalExpression(String[] data) {
        for (String str:data
             ) {
            set.add(str);
        }
    }

    @Override
    public boolean Interprete(String info){
        return set.contains(info);
    }

}
(2) 模板方法模式

2、对象模式

(1) 责任链模式

在这里插入图片描述

在这里插入图片描述

/**
 * 责任链模式。类似审批流、也可以理解为连带责任。各处理对象间有条隐形的链。
 * 此处以请假审批流为例
 */
public class ChainOfResponsibilityPattern {
    public static void main(String[] args) {
        Handler concreteHandler1 = new ConcreteHandler1();
        Handler concreteHandler2 = new ConcreteHandler2();

        concreteHandler1.setNext(concreteHandler2);
        concreteHandler1.HandleRequest(8);
    }
}

// 处理类父类
abstract class Handler {
    protected Handler next;   // 我处理不了,要将这个请求转给next

    public void setNext(Handler next){
        this.next = next;
    }

    abstract public void HandleRequest(int request);
}

// 处理类子类。明确知道了谁处理了我的请求,我处理不了,就给ConcreteHandler2
// 可以理解成甩锅,这锅我背不了,甩给另一个。
class ConcreteHandler1 extends Handler{

    @Override
    public void HandleRequest(int request) {
        if(request <=7){
            System.out.println("ConcreteHandler1 审批通过");
        }else {
            if(next != null){
                next.HandleRequest(request);
            }else {
                System.out.println("无法审批");
            }
        }
    }
}

// 处理类子类。明确知道了谁处理了我的请求,我处理不了,就给ConcreteHandler2
class ConcreteHandler2 extends Handler {

    @Override
    public void HandleRequest(int request) {
        if(request < 20){
            System.out.println("ConcreteHandler2 审批通过");
        }else {
            if(next != null){
                next.HandleRequest(request);
            }else {
                System.out.println("无法审批");
            }
        }
    }
}

(2) 命令模式

在这里插入图片描述

在这里插入图片描述

/**
 * 命令模式。此处以遥控器发出命令控制电视机的开关为例
 */
public class CommandPattern {
    public static void main(String[] args) {
        Receiver receiver = new Receiver();

        Command commandOne = new CommandOne(receiver);
        Command commandTwo = new CommandTwo(receiver);

        Invoker invoker = new Invoker();
        // 开机操作
        invoker.setCommand(commandOne);
        invoker.call();
        // 关机操作
        invoker.setCommand(commandTwo);
        invoker.call();
    }
}

// 请求者。类似遥控器
class Invoker {
    private Command command;
    public void setCommand(Command command){
        this.command = command;
    }

    public void call() {
        command.Execute();
    }
}

// 命令接口
interface Command {
    public void Execute();
}


// 明确的命令1
class CommandOne implements Command {
    private Receiver recevier;

    public CommandOne(Receiver recevier){
        this.recevier = recevier;
    }

    @Override
    public void Execute() {
        recevier.open();
    }
}

// 明确的命令2
class  CommandTwo implements Command {
    private Receiver recevier;

    public CommandTwo(Receiver recevier){
        this.recevier = recevier;
    }

    @Override
    public void Execute() {
        recevier.close();
    }
}

// 命令的接收者。类似于电视机
class Receiver {
    public void open() {
        System.out.println("开机操作");
    }
    public void close() {
        System.out.println("关机操作");
    }
}
(3) 迭代器模式

在这里插入图片描述

(4) 解释器模式

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

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

相关文章

MD-MTSP:孔雀优化算法POA求解多仓库多旅行商问题(提供MATLAB代码,可以修改旅行商个数及起点)

一、多仓库多旅行商问题 多旅行商问题&#xff08;Multiple Traveling Salesman Problem, MTSP&#xff09;是著名的旅行商问题&#xff08;Traveling Salesman Problem, TSP&#xff09;的延伸&#xff0c;多旅行商问题定义为&#xff1a;给定一个&#x1d45b;座城市的城市集…

Midjourney8种风格极其使用场景

目录 ​编辑 引言 等距动画 场景 分析性绘图 场景 着色书 场景 信息图画 场景 双重曝光 场景 图示性绘画 场景 二维插图 场景 图解式画像 场景 总结&#xff1a; 八种风格箴言&#xff1a; 引言 我相信大家都或多或少玩过Midjourney&#xff0c;但是要形…

linux系统sed编辑器

sed编辑器 sed编辑器sed基础语法sed查询sed删除sed 替换sed 插入 sed编辑器 sed是文本处理工具&#xff0c;依赖于正则表达式&#xff0c;可以读取文本内容&#xff0c;工具指定条件对数据进行添加、删除、替换等操作&#xff0c;被广泛应用于shell脚本&#xff0c;以完成自动…

我所了解的老板

我所了解的老板 修心篇以名命物 扰我心良心的本来如此 是我心不要全挑剔别人 既是我因 受我之果长久之爱 美女养眼 贤妻养心 调研篇深度思考确定趋势确定时机预测筹划生存资料 做事篇做短视频心态&#xff0c;也是创业的心态做销售冠军的心态&#xff0c;也是创业的心态 修心篇…

【Python--定时任务的四种方法】

定时任务 前言while True&#xff1a;sleep()优点缺点 threading.Timer定时器多线程执行优点缺点 Timeloop库执行定时任务调度模块schedule优缺点 前言 当每隔一段时间就要执行一段程序&#xff0c;或者往复循环执行某一个任务&#xff0c;这就需要使用定时任务来执行程序。应…

【Unity项目实战】手把手教学:飞翔的小鸟(7)障碍对象池

承接上一篇&#xff1a;【Unity项目实战】手把手教学&#xff1a;飞翔的小鸟&#xff08;6&#xff09;添加障碍&#xff0c;我们已经生成了一个障碍物柱子&#xff0c;并且使得小鸟在越过柱子之后自动获得一分&#xff0c;接下来将继续讲解障碍物的随机生成。 一.脚本控制 障…

Centos7设置静态IP

Centos7设置静态IP及修改后不能联网问题解决方式 虚拟机外部配置1、打开Vmware选择虚拟网络编辑器菜单2、获取管理员权限&#xff0c;选择VMnet8&#xff0c;并点击还原默认设置&#xff0c;弹窗选择“是”。3、修改VMnet8的参数4、NAT设置5、确认虚拟机为NAT模式 虚拟机内部配…

数据流图(DFD)

目录 第十二章、数据流图&#xff08;DFD&#xff09;1、数据流图基本概念2、数据字典3、数据平衡原则4、数据流图试题解题技巧4.1、试题一4.2、试题二 第十二章、数据流图&#xff08;DFD&#xff09; 1、数据流图基本概念 数据流图是用于表示系统逻辑模型的一种工具。从数据…

【Swift】Swift和Objective-c混编

1.介绍 Swift和Objective-C都是苹果公司的编程语言&#xff0c;它们可以在同一个项目中同时使用。这种混编方式被称为“混合编程”&#xff08;Mixed Programming&#xff09;。 在混合编程时&#xff0c;我们需要用到一个桥接文件&#xff08;Bridging Header&#xff09;&a…

AfxMessageBox的两种用法

1 函数简介 函数声明如下&#xff1a; int AfxMessageBox(LPCTSTR lpszText,UINT nType MB_OK,UINT nIDHelp 0 ); int AFXAPI AfxMessageBox(UINT nIDPrompt,UINT nType MB_OK,UINT nIDHelp (UINT ) -1 );1.1 参数 lpszText 将显示在消息框的字符串。 nType 消息框…

使用Selenium模拟百度登录

前言 前面我已经安装好了Selenium并模拟成功了一下打开百度页面并进行查询&#xff0c;让我这个python初学者信心倍增&#xff0c;今天再来试一试百度登录 正文 把打开百度的代码放到构造方法中 ps:那个文件目录是用于后面滑块验证图片保存的。 def __init__(self):driver w…

Python实战基础8-列表

一、列表的基本使用 1.列表的格式 定义列的格式&#xff1a;[元素1&#xff0c;元素2&#xff0c;元素3&#xff0c;...&#xff0c;元素n] 变量tmp的类型为列表 tmp [XiaoChen,180,66.0] 列表中的元素可以是不同类型的 2.使用下标获取列表元素 namesList [XiaoChen,Xia…

上海AI lab提出VideoChat:可以与视频对话啦

夕小瑶科技说 原创 作者 | 小戏、ZenMoore 视频相比语言、图像&#xff0c;是更复杂更高级的一类表征世界的模态&#xff0c;而视频理解也同样是相比自然语言处理与计算机视觉的常见工作更复杂的一类工作。在当下大模型的洪流中&#xff0c;自然而然的想法就是大规模语言模型…

子矩形计数(多少个面积为k的全1子矩阵)【思维,两个一维数组相乘得到矩阵,计算一维数组中长度为x的全1子段】

3617. 子矩形计数&#xff08;多少个面积为k的全1子矩阵&#xff09; 输入样例1&#xff1a; 3 3 2 1 0 1 1 1 1输出样例1&#xff1a; 4输入样例2&#xff1a; 3 5 4 1 1 1 1 1 1 1 1输出样例2&#xff1a; 14#include <bits/stdc.h> using namespace std; #define …

Redisson锁的分析

文章目录 一、分布式锁概念1、实现思路2、出现死锁问题如何避免死锁问题 锁过期和释放当前不属于当前线程的锁解决不是加锁线程释放锁锁的过期时间如何解决 二、Redisson分布式锁Redis的部署方式对锁的影响集群模式Redlock实现高可靠的分布式锁 三、代码分析V1代码无锁V2代码单…

【C++从0到王者】第二站:类和对象(中)赋值运算符重载

文章目录 一、运算符重载1.运算符重载的使用2.运算符重载的注意事项 二、赋值运算符重载1.复制拷贝与拷贝构造2.赋值运算符重载的格式3.赋值运算符重载的实现4.赋值运算符重载的注意事项 一、运算符重载 1.运算符重载的使用 当我们实现一个日期类的时候&#xff0c;我们有时候…

Angular开发之——Angular打包部署项目(04)

一 概述 ng build 构建应用lite-server介绍及安装lite-server部署应用IIS管理器部署应用 二 ng build 构建应用 2.1 执行如下指令构建应用 ng build2.2 构建完成后&#xff0c;会创建一个 dist 文件夹 2.3 直接打开index.html会出错(需要借助于服务器部署) 三 lite-server介…

(二)PUN 2基本教程

一、介绍 PUN 基础教程是一个基于 Unity 的教程。我们将使用 Photon Cloud 开发第一个简单的 PUN 2 多人游戏。目标是同步每个玩家的动画角色、健康值和基本光线投射。 1.概述 本教程将从一个空项目开始&#xff0c;逐步指导您完成整个创建过程。在此过程中&#xff0c;将解释…

Halcon 形态学 开发案例 (开运算opening(先腐蚀再膨胀)、闭运算closing(先膨胀再腐蚀))

文章目录 1 形态学概念2 开运算 opening2.1 算子介绍2.2 开运算 开发案例3 闭运算 closing3.1 算子介绍3.2 闭运算 开发案例4 示例原图1 形态学概念 图像的形态学处理是对图像的局部像素进行处理,用于从图像中提取有意义的局部图像细节。 通过改变局部区域的像素形态,以对目…

数据结构与算法基础知识

线性结构篇 什么是数据结构与算法 回顾我们之前的C语言程序设计阶段&#xff0c;我们已经接触过基本数据类型&#xff0c;并且能够使用结构体对数据进行组织&#xff0c;我们可以很轻松地使用一个结构体来存放一个学生的完整数据&#xff0c;在数据结构学习阶段&#xff0c;我…