设计模式之委派模式(行为型)

本文介绍了委派模式的概念和应用场景,通过代码示例展示了如何在 Leader 类中实现任务的委派,使得 Leader 只关注结果而不参与具体任务的执行。在实际应用中,如 ClassLoader 的 LoadClass 方法和 Method 的 invoke 方法,都体现了委派模式的思想。委派模式简化了任务处理,增强了代码的灵活性和可扩展性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

概念和应用场景

  • 概念
    作用是负责任务的调用和分配任务,是一种特殊的静态代理,区别是代理模式注重过程,委派模式注重结果

写法

public class Boss {
    public void command(String task,Leader leader){
        leader.doing(task);
    }
}
public interface IEmployee {
    void doing(String task);
}
public class EmployeeA implements IEmployee {
    protected String goodAt = "编程";
    public void doing(String task) {
        System.out.println("我是员工A,我擅长" + goodAt + ",现在开始做" +task + "工作");
    }
}
public class EmployeeB implements IEmployee {
    protected String goodAt = "平面设计";
    public void doing(String task) {
        System.out.println("我是员工B,我擅长" + goodAt + ",现在开始做" +task + "工作");
    }
}

Leader类只负责分配

public class Leader implements IEmployee {

    private Map<String,IEmployee> employee = new HashMap<String,IEmployee>();

    public Leader(){
        employee.put("爬虫",new EmployeeA());
        employee.put("海报图",new EmployeeB());
    }

    public void doing(String task) {
        if(!employee.containsKey(task)){
            System.out.println("这个任务" +task + "超出我的能力范围");
            return;
        }
        employee.get(task).doing(task);
    }
}
public class Test {
    public static void main(String[] args) {
        new Boss().command("海报图",new Leader());
        new Boss().command("爬虫",new Leader());
        new Boss().command("卖手机",new Leader());
    }
}

在这里插入图片描述

源码中的应用

ClassLoader类的LoadClass方法,即双亲委派机制
在这里插入图片描述
Method类的invoke方法委托给了ma去做,自己只返回结果
在这里插入图片描述
总结,它有点门面模式那种感觉,不过它只作用于方法,不像门面模式是封装全部的接口

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值