首页 > 代码库 > 设计模式——装饰模式
设计模式——装饰模式
很简单,我就是想调用A方法的时候(前后),额外调用一些其他方法:
package designpattern.structure.decorator;/* * Decorator它的做法跟代理模式,很相似,但是对work的实现不同 —— * 如果是Decorator在work实现中直接调用ITarget的work, 则变成了代理模式!!不是! * * ———— 如果是Decorator的构造器参数去掉,构造器内部对target赋值, 则变成了代理模式! */public class Decorator implements ITarget { private ITarget target; public Decorator(ITarget target){ super(); this.target = target; } public void work() { System.out.println("before work!"); // 此处即为装饰!亦即装饰模式的主要目的 target.work(); System.out.println("after work!"); // 此处即为装饰!亦即装饰模式的主要目的 } } package designpattern.structure.decorator;public interface ITarget { public void work();}package designpattern.structure.decorator;public class Target implements ITarget { public void work() { System.out.println("Target.work()"); }}package designpattern.structure.decorator;/** * * * 1 装饰模式就是给一个对象增加一些新的功能,而且是动态的, * 2 要求装饰对象和被装饰对象实现同一个接口, * 3 装饰对象持有被装饰对象的实例 * * 步骤: * 1 想让ITarget工作,但是想在原有实现Target上附加一些功能 * * @author Administrator * */public class Client { /** * @param args */ public static void main(String[] args) { ITarget target = new Decorator(new Target()); target.work(); }}
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。