Go和Java实现装饰器模式

这篇具有很好参考价值的文章主要介绍了Go和Java实现装饰器模式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Go和Java实现装饰器模式

我们通过人穿着打扮自己的实例来演示装饰器模式的用法。

1、装饰器模式

装饰器模式允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它

是作为现有的类的一个包装。

装饰器模式通过将对象包装在装饰器类中,以便动态地修改其行为。

这种模式创建了一个装饰类,用来包装原有的类,并在保持类方法签名完整性的前提下,提供了额外的功能。

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

  • 主要解决:一般的,我们为了扩展一个类经常使用继承方式实现,由于继承为类引入静态特征,并且随着扩展

    功能的增多,子类会很膨胀。

  • 何时使用:在不想增加很多子类的情况下扩展类。

  • 如何解决:将具体功能职责划分,同时继承装饰者模式。

  • 关键代码:1、Component 类充当抽象角色,不应该具体实现。 2、修饰类引用和继承 Component 类,具

    体扩展类重写父类方法。

  • 应用实例:1、孙悟空有 72 变,当他变成"庙宇"后,他的根本还是一只猴子,但是他又有了庙宇的功能。 2、

    不论一幅画有没有画框都可以挂在墙上,但是通常都是有画框的,并且实际上是画框被挂在墙上。在挂在墙上

    之前,画可以被蒙上玻璃,装到框子里;这时画、玻璃和画框形成了一个物体。

  • 优点:装饰类和被装饰类可以独立发展,不会相互耦合,装饰模式是继承的一个替代模式,装饰模式可以动态

    扩展一个实现类的功能。

  • 缺点:多层装饰比较复杂。

  • 使用场景:1、扩展一个类的功能。 2、动态增加功能,动态撤销。

  • 注意事项:可代替继承。

  • 装饰器模式包含以下几个核心角色:

    抽象组件(Component):定义了原始对象和装饰器对象的公共接口或抽象类,可以是具体组件类的父类或

    接口。

    具体组件(Concrete Component):是被装饰的原始对象,它定义了需要添加新功能的对象。

    抽象装饰器(Decorator):继承自抽象组件,它包含了一个抽象组件对象,并定义了与抽象组件相同的接

    口,同时可以通过组合方式持有其他装饰器对象。

    具体装饰器(Concrete Decorator):实现了抽象装饰器的接口,负责向抽象组件添加新的功能。具体装饰

    器通常会在调用原始对象的方法之前或之后执行自己的操作。

  • 适用性:

    在不影响其他对象的情况下,以动态、透明的方式给单个对象添加职责。

    处理那些可以撤消的职责。

    当不能采用生成子类的方法进行扩充时。

装饰器模式通过嵌套包装多个装饰器对象,可以实现多层次的功能增强。每个具体装饰器类都可以选择性地增加新

的功能,同时保持对象接口的一致性。文章来源地址https://www.toymoban.com/news/detail-625108.html

2、Go实现装饰器模式

package decorator

// ========== Person ==========
type Person interface {
	// 形象展示
	Show()
}
package decorator

import "fmt"

// ========== 服饰类 ==========
type Finery struct {
}

func (finery *Finery) Show() {
	fmt.Println("穿着了如下衣服:")
}
package decorator

// ========== FineryDecorator =========
type FineryDecorator interface {
	Decorate(Person)
}
package decorator

import "fmt"

// ========== Tshirt =========
type Tshirt struct {
	person Person
}

func (tshirt *Tshirt) Decorate(person Person) {
	tshirt.person = person
}

func (tshirt *Tshirt) Show() {
	tshirt.person.Show()
	fmt.Println("大T恤")
}
package decorator

import "fmt"

// ========== Trouser =========
type Trouser struct {
	person Person
}

func (trouser *Trouser) Decorate(person Person) {
	trouser.person = person
}

func (trouser *Trouser) Show() {
	trouser.person.Show()
	fmt.Println("阔腿裤")
}
package decorator

import "fmt"

// ========== Shoe =========
type Shoe struct {
	person Person
}

func (shoe *Shoe) Decorate(person Person) {
	shoe.person = person
}

func (shoe *Shoe) Show() {
	shoe.person.Show()
	fmt.Println("运动鞋")
}
package main

import . "proj/decorator"

func main() {
	person := &Finery{}
	tshirt := &Tshirt{}
	trouser := &Trouser{}
	shoe := Shoe{}

	tshirt.Decorate(person)
	trouser.Decorate(tshirt)
	shoe.Decorate(trouser)
	shoe.Show()
}

# 输出
穿着了如下衣服:
大T恤
阔腿裤
运动鞋

3、Java实现装饰器模式

package com.decorator;

// ========== Person ==========
public interface Person {
    // 形象展示
    void show();
}
package com.decorator;

// ========== 服饰类 ==========
public class Finery implements Person{
    @Override
    public void show() {
        System.out.println("穿着了如下衣服:");
    }
}
package com.decorator;

// ========== FineryDecorator =========
public class FineryDecorator implements Person{

    protected Person person;

    public void decorator(Person person){
        this.person = person;
    }

    @Override
    public void show() {
        this.person.show();
    }
}
package com.decorator;

// ========== Tshirt =========
public class Tshirt extends FineryDecorator{

    @Override
    public void show() {
        super.show();
        System.out.println("大T恤");
    }
}
package com.decorator;

// ========== Trouser =========
public class Trouser extends FineryDecorator {

    @Override
    public void show() {
        super.show();
        System.out.println("阔腿裤");
    }

}
package com.decorator;

// ========== Shoe =========
public class Shoe extends FineryDecorator{

    @Override
    public void show() {
        super.show();
        System.out.println("运动鞋");
    }
}
package com.decorator;

public class Test {

    public static void main(String[] args) {
        Person person = new Finery();
        FineryDecorator fineryDecorator = new FineryDecorator();
        Tshirt tshirt = new Tshirt();
        Trouser trouser = new Trouser();
        Shoe shoe = new Shoe();
        fineryDecorator.decorator(person);
        tshirt.decorator(fineryDecorator);
        trouser.decorator(tshirt);
        shoe.decorator(trouser);
        shoe.show();
    }
}
# 输出
穿着了如下衣服:
大T恤
阔腿裤
运动鞋

到了这里,关于Go和Java实现装饰器模式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java设计模式之结构型-装饰器模式(UML类图+案例分析)

    目录 一、基本概念 二、UML类图 三、角色设计 四、代码实现 案例一 案例二  五、总结  装饰器模式是指不必在改变原有的类和不使用继承的情况下,动态扩展一个对象的功能。 角色 描述 抽象构件 是一个接口或者抽象类,定义我们最核心的对象 具体构件 抽象构件的实现,

    2024年02月11日
    浏览(35)
  • 《golang设计模式》第二部分·结构型模式-04-装饰器模式(Decorator)

    装饰器(Decorator)通过包装(不是继承)的方式向目标对象中动态地添加或删除功能。 Component(抽象组件):定义了原始对象的接口,装饰器也会实现这个接口。 Concrete Component(具体组件):原始对象,以后装饰器会装饰它。 Decorator(抽象装饰器):关联/聚合了抽象组件,

    2024年02月09日
    浏览(49)
  • 简化代码结构与提高灵活性:学习Java设计模式中的装饰器模式

    简化代码结构与提高灵活性:学习Java设计模式中的装饰器模式 在软件开发中,我们经常会遇到需要在不修改现有代码的情况下,对已有对象进行功能扩展或修改的需求。此时,装饰器模式就是一种非常有用的设计模式,它通过动态地将责任附加到对象上,来扩展对象的功能

    2024年02月16日
    浏览(45)
  • 【代理设计模式详解】C/Java/JS/Go/Python/TS不同语言实现

    代理模式(Proxy Pattern)是一种结构型设计模式,用一个类来代理另一个类或几个类的功能。 在代理模式中,我们创建具有现有对象的对象,以便向外界提供功能接口。 延迟初始化(虚拟代理)。如果你有一个偶尔使用的重量级服务对象,一直保持该对象运行会消耗系统资源

    2023年04月25日
    浏览(80)
  • 【单例设计模式原理详解】Java/JS/Go/Python/TS不同语言实现

    单例模式(Singleton Pattern)属于创建型设计模式,这种模式只创建一个单一的类,保证一个类只有一个实例,并提供一个访问该实例的全局节点。 当您想控制实例数目,节省系统资源,并不想混用的时候,可以使用单例模式。单例有很多种实现方式,主要分为懒汉和饿汉模式

    2023年04月27日
    浏览(88)
  • 【原型设计模式详解】C/Java/JS/Go/Python/TS不同语言实现

    原型模式(Prototype Pattern)是一种创建型设计模式,使你能够复制已有对象,而无需使代码依赖它们所属的类,同时又能保证性能。 这种模式是实现了一个原型接口,该接口用于创建当前对象的克隆。当直接创建对象的代价比较大时,则采用这种模式。 如果你需要复制一些对

    2023年04月24日
    浏览(79)
  • 【策略设计模式详解】C/Java/JS/Go/Python/TS不同语言实现

    策略模式(Strategy Pattern)属于行为型设计模式。将每一个算法封装到具有共同接口的独立类中,根据需要来绑定策略,使得具体实现和策略解耦。 当你想使用对象中各种不同的算法变体,使用if...else 所带来的复杂和难以维护,可使用策略模式。或者当有许多相同类,它们仅

    2024年02月01日
    浏览(42)
  • 【模板方法设计模式详解】C/Java/JS/Go/Python/TS不同语言实现

    模板方法模式(Template Method Pattern)也叫模板模式,是一种行为型模式。它定义了一个抽象公开类,包含基本的算法骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变算法的结构,只是重定义该算法的某些特定步骤。不同的子类以不同的方式实现这些抽象方法

    2024年02月01日
    浏览(80)
  • 【迭代器设计模式详解】C/Java/JS/Go/Python/TS不同语言实现

    迭代器模式(Iterator Pattern),是一种结构型设计模式。给数据对象构建一套按顺序访问集合对象元素的方式,而不需要知道数据对象的底层表示。 迭代器模式是与集合共存的,我们只要实现一个集合,就需要同时提供这个集合的迭代器,就像Java中的Collection,List、Set、Map等

    2023年04月17日
    浏览(45)
  • 【享元设计模式详解】C/Java/JS/Go/Python/TS不同语言实现

    享元模式(Flyweight Pattern),是一种结构型设计模式。主要用于减少创建对象的数量,以减少内存占用和提高性能。它摒弃了在每个对象中保存所有数据的方式,通过共享多个对象所共有的相同状态,让你能在有限的内存容量中载入更多对象。 当程序需要生成数量巨大的相似

    2023年04月10日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包