装饰者设计模式(二)番外篇 装饰者设计模式和静态代理设计模式区别

简介: 装饰者设计模式(二)番外篇 装饰者设计模式和静态代理设计模式区别

一、内容提要

本文主要是对静态代理设计模式和装饰者设计模式进行比较,总结一下他们之间的相同和不同之处。

二、代码描述

如果对装饰者设计模式不太熟悉的同学,可以看之前的文章:装饰者设计模式(一)

1、开发简单的装饰者类

目标类接口ISomeService 
package com.proxy;
/**
 * 业务逻辑接口
 */
public interface ISomeService {
    //目标方法
    String doSome();
}
目标实现类SomeService 
package com.proxy;
/**
 * 目标类
 */
public class SomeService implements ISomeService {
    @Override
    public String doSome() {
        return "abcde";
    }
}
装饰者类SomeServiceDecorator 
package com.decorator;
/**
 * 装饰者:
 *      1、装饰者类与目标类要实现相同的接口,或继承自相同的抽象类
 *      2、装饰者类中要有目标类的引用作为成员变量,而具体的实现一般通过带参构造器完成
 */
public class SomeServiceDecorator implements ISomeService {
    //目标对象
    private ISomeService target;
    //通过带参构造器传入目标对象
    public SomeServiceDecorator(ISomeService target) {
        this.target = target;
    }
    @Override
    public String doSome() {
        return target.doSome().toUpperCase();
    }
}

2、开发简单的静态代理类

目标类接口和目标实现类,其实和上面一样的,我还是再写一遍吧,防止大家看蒙了

目标类接口ISomeService 
package com.proxy;
/**
 * 业务逻辑接口
 */
public interface ISomeService {
    //目标方法
    String doSome();
}
目标实现类SomeService 
package com.proxy;
/**
 * 目标类
 */
public class SomeService implements ISomeService {
    @Override
    public String doSome() {
        return "abcde";
    }
}
静态代理类SomeServiceProxy 
package com.proxy;
/**
 * 静态代理类:
 */
public class SomeServiceProxy implements ISomeService {
    private ISomeService target;
    //  在无参构造器中直接创建目标对象,对外界隐藏目标类对象
    public SomeServiceProxy() {
        this.target = new SomeService();
    }
    @Override
    public String doSome() {
        return target.doSome().toUpperCase();
    }
}

测试类跑一下

package com.proxy;
public class Test {
    public static void main(String[] args) {
        ISomeService target = new SomeServiceProxy();
        System.out.println(target.doSome());//ABCDE
    }
}

三、区别

静态代理模式和装饰者模式,最本质的区别就是 创建对象的方式不一样。

首先 装饰者模式,创建对象是通过带参构造器来实现的。
public class SomeServiceDecorator implements ISomeService {
    //目标对象
    private ISomeService target;
    //通过带参构造器传入目标对象
    public SomeServiceDecorator(ISomeService target) {
        this.target = target;
    }
而 静态代理模式 是通过无参构造器,直接创建的,目的是为了保护和隐藏目标类对象
public class SomeServiceProxy implements ISomeService {
    private ISomeService target;
    //  在无参构造器中直接创建目标对象,对外界隐藏目标类对象
    public SomeServiceProxy() {
        this.target = new SomeService();
    }

细心的同学会发现,测试类中,并没有看到目标实对象,而是只看到了代理类,这就是为了隐藏对象而设计的

public static void main(String[] args) {
    //没有看到目标类对象SomeService ,只有代理类SomeServiceProxy
        ISomeService target = new SomeServiceProxy();
        System.out.println(target.doSome());//ABCDE
    }

四、总结

相同点:

1、都要实现与目标类相同的业务接口

2、这两个类中都要声明目标对象

3、都可以在不修改目标类的前提下增强目标方法

区别:

1、目的不同:装饰者的使用目的就是增强目标对象;而静态代理类的目的是为了保护和隐藏目标对象

2、对目标对象的获取方式不同:

装饰者类中目标对象的获取,是通过带参构造器来传入

静态代理类中目标对象的获取,是直接在无参构造器中创建,而非用户传过来的,因为要保护和隐藏对象。

3、功能增强的实现者不同:

装饰者设计模式中存在装饰者基类或父类,其并不真正实现增强,而是由具体的装饰者进行功能增强的,所以存在一个“装饰者链”的概念

静态代理设计模式中,一般不存在父子类的关系,具体的增强就是由代理类完成,无需由子类完成,所以不存在“链”的概念


目录
打赏
0
0
0
0
5
分享
相关文章
MVVM、MVC、MVP三种常见软件架构设计模式的区别
MVC、MVP 和 MVVM 是三种常见的软件架构设计模式,主要通过分离关注点的方式来组织代码结构,优化开发效率。
178 12
课时90:代理设计模式
课时90介绍了代理设计模式,该模式通过代理对象帮助用户专注于核心业务功能。代理模式中,客户端只关注核心业务(如“吃”),而代理对象负责准备、执行和清理工作。通过接口IEat、真实主题EatReal和服务代理EatProxy的实现,展示了如何在代码中应用代理模式。代理模式的特点是将业务逻辑与辅助操作分离,使代码更清晰且易于维护。
设计模式3:代理、适配器、装饰器模式
代理模式是一种结构型设计模式,通过中间件解耦服务提供者和使用者,使使用者间接访问服务提供者,便于封装和控制。
41 2
05.静态代理设计模式
《静态代理设计模式》详细介绍了静态代理的基本概念、原理与实现、应用场景及优缺点。主要内容包括静态代理的由来、定义、使用场景、实现方式、结构图与时序图,以及其在降低耦合、保护对象权限等方面的优势。同时,文章也指出了静态代理的局限性,如缺乏灵活性、难以复用、难以动态添加功能等,并介绍了动态代理如何弥补这些不足。最后,通过多个实际案例和代码示例,帮助读者更好地理解和应用静态代理模式。
62 4
spring源码设计模式分析-代理设计模式(二)
spring源码设计模式分析-代理设计模式(二)
利用 Xamarin 开展企业级移动应用开发:从用户登录到客户管理,全面演示C#与Xamarin.Forms构建跨平台CRM应用的实战技巧与代码示例
【8月更文挑战第31天】利用 Xamarin 进行企业级移动应用开发能显著提升效率并确保高质量和高性能。Xamarin 的跨平台特性使得开发者可以通过单一的 C# 代码库构建 iOS、Android 和 Windows 应用,帮助企业快速推出产品并保持一致的用户体验。本文通过一个简单的 CRM 示例应用演示 Xamarin 的使用方法,并提供了具体的代码示例。该应用包括用户登录、客户列表显示和添加新客户等功能。此外,还介绍了如何增强应用的安全性、数据持久化、性能优化及可扩展性,从而构建出功能全面且体验良好的移动应用。
76 0
Ruby设计模式大揭秘!代理VS装饰器,你选对了让代码起舞的魔法棒吗?
【8月更文挑战第31天】在软件开发中,设计模式能够提升代码质量和团队协作效率。本文将介绍Ruby中的两种重要模式:代理(Proxy)和装饰器(Decorator)。代理模式通过中间对象控制对目标对象的访问,适用于访问控制、延迟加载等场景;装饰器模式则允许在不改变原对象结构的情况下动态添加新功能,比生成子类更灵活。通过具体示例代码,我们将深入理解这两种模式的实现和应用,帮助开发者更好地选择合适的模式解决问题。
60 0
依赖注入与工厂设计模式的区别
【8月更文挑战第22天】
109 0
【设计模式】适配器和桥接器模式有什么区别
【设计模式】适配器和桥接器模式有什么区别
204 1
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等