• 安卓常见设计模式------装饰器模式(Kotlin版)


    1. W1 是什么,什么是装饰器模式?

    1. 思想:动态地给对象添加额外的功能,通过将对象包装在一个装饰器类中,使装饰器类在不改变原始对象结构的情况下,扩展其功能。

    2. W2 为什么,为什么需要使用装饰器模式,使用装饰器模式能给我们编码带来什么好处?

    1. 扩展功能: 装饰者模式允许在运行时动态地添加或修改对象的功能。这样就可以通过添加装饰器来扩展一个对象的功能,而无需修改原始对象的代码。这种灵活性使得在不改变现有代码的情况下,可以方便地添加新的功能或修改现有功能。

    2. 遵循开闭原则: 装饰者模式支持开闭原则,即对扩展开放,对修改关闭。通过使用装饰者模式,可以在不修改现有代码的情况下,通过添加新的装饰器来扩展对象的功能。这样就可以减少对原始对象的修改,提高代码的稳定性和可维护性。

    3. 代码复用性: 装饰者模式可以促进代码的复用。你可以将不同的装饰器组合在一起,以创建不同的功能组合。这样可以避免创建大量重复的子类或复制粘贴代码的情况,从而提高代码的可复用性。

    4. 细粒度控制: 装饰者模式允许以细粒度的方式控制对象的功能。通过添加不同的装饰器,你可以选择性地启用或禁用特定的功能,或按需组合功能。这样可以根据具体需求灵活地定制对象的行为。

    5. 透明性: 使用装饰者模式可以保持对象接口的一致性。装饰器和原始对象实现相同的接口,这使得装饰后的对象可以透明地替代原始对象,而不会破坏现有的代码结构。这种透明性使得客户端代码无需关心对象是否被装饰,从而简化了代码的使用和维护。

    3. W3,如何使用?

    1. 在装饰者模式中,有一个抽象组件(Component)作为基础类,定义了对象的基本行为。然后,有一个具体组件(ConcreteComponent)实现了抽象组件,并提供了基本行为的具体实现。

    2. 除了抽象组件和具体组件外,还有一个装饰器(Decorator)类,它实现了抽象组件的接口,并持有一个抽象组件的引用。装饰器类可以在运行时动态地添加额外的功能或修改原始组件的行为。

    3. 下面是装饰者模式的主要参与者:

      Component(抽象组件):定义了对象的基本行为,可以是接口或抽象类。

      ConcreteComponent(具体组件):实现了抽象组件,并提供了基本行为的具体实现。

      Decorator(装饰器):持有一个抽象组件的引用,并实现了抽象组件的接口。可以在运行时动态地添加额外的功能。

      ConcreteDecorator(具体装饰器):扩展了装饰器类,添加了具体的功能或修改了原始组件的行为。

    4. 装饰者模式的核心思想是通过组合而不是继承来实现对象的功能扩展。它使得可以在运行时动态地添加、移除或修改对象的行为,而无需修改现有代码。

    5. 下面是代码示例:

    // 定义一个基本的文本显示接口
    interface TextDisplay {
        fun displayText(): String
    }
    
    // 实现基本的文本显示类
    class SimpleTextDisplay(private val text: String) : TextDisplay {
        override fun displayText(): String {
            return text
        }
    }
    
    // 定义装饰器接口
    interface TextDecorator : TextDisplay
    
    // 实现具体的装饰器类1 加粗
    class BoldTextDecorator(private val textDisplay: TextDisplay) : TextDecorator {
        override fun displayText(): String {
            val text = textDisplay.displayText()
            return "$text"
        }
    }
    
    // 实现具体的装饰器类2 斜体
    class ItalicTextDecorator(private val textDisplay: TextDisplay) : TextDecorator {
        override fun displayText(): String {
            val text = textDisplay.displayText()
            return "$text"
        }
    }
    
    // 使用示例
    val originalText = "Hello, World!"
    val simpleDisplay: TextDisplay = SimpleTextDisplay(originalText)
    
    // 添加装饰器来修饰文本
    val boldTextDisplay: TextDisplay = BoldTextDecorator(simpleDisplay)
    val italicTextDisplay: TextDisplay = ItalicTextDecorator(simpleDisplay)
    
    // 输出修饰后的文本
    println(boldTextDisplay.displayText())   // 输出: Hello, World!
    println(italicTextDisplay.displayText()) // 输出: Hello, World!
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42

    Thank you for your reading, have a nice day!

  • 相关阅读:
    实战 target 选择器,解放生产力!
    QIBOX1-014-栏目的调用2
    python 生成器
    阿里云云效流水线教程
    Kotlin 中 apply、let、also、run的区别
    Java之final和abstract关键字(9)
    Android开发中关于Ui的语法糖
    数据库字段中使用逗号拼接,需要查询数据时
    同样是IT行业,测试和开发薪资真有这么大差别?
    gdb core调试实践
  • 原文地址:https://blog.csdn.net/qq_42751010/article/details/134261388