Java中动态代理、装饰模式和继承简单实现

继承

被增强的对象固定的
增强的内容也是固定的

装饰者模式

被增强的对象是可以切换的
增强的内容是固定的

还有一种更加灵活的方式,面向切面编程(AOP) ,比装饰者模式更加灵活, 被增强的对象和增强的内容都是可以更换的.

注意:只能增强接口特有的方法,不能增强类特有的方法

package cn.ph.proxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
//使用代理模式
public class MyCar {
	public static void main(String[] args) {
	// Object java.lang.reflect.Proxy.newProxyInstance
	// (ClassLoader loader, Class<?>[] interfaces, InvocationHandler h) throws IllegalArgumentException
	// 参数类型
	/**
	 * param1:告诉虚拟机用哪个字节码加载器加载对应的字节码文件,固定值
	 * param2:告诉虚拟机正在被创建的字节码有哪些方法
	 * param3:告诉虚拟机正在被创建的字节码文件的各个方法如何处理
	 * 编译过后会生成对应的代理文件  MyCar$1.class
	 */
	Car car = (Car) Proxy.newProxyInstance(MyCar.class.getClassLoader(), GoogleCar.class.getInterfaces(),
			new InvocationHandler() {

				@Override
				public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
					// 每个方法中执行的代码
					if ("start".equals(method.getName())) {// method.getName().equalsIgnoreCase("start") //忽略大小写
						System.out.println(method.getName());// 增强start方法
					}
					method.invoke(new GoogleCar());
					return null;
				}
			});
	car.start();// 执行上面invoke方法
	car.run();
	car.stop();

}

}
//引用装饰者模式
class TestCar implements Car {
private Car car;

public TestCar(Car car) {
	this.car = car;
}

@Override
public void run() {
	car.run();
}

@Override
public void start() {
	System.out.println("查看天气");
	System.out.println("检查路况");
	car.start();
}

@Override
public void stop() {
	car.stop();
}

}

class GoogleCar implements Car {

@Override
public void start() {
	System.out.println("车启动了");
}

@Override
public void run() {
	System.out.println("车运行了");

}

@Override
	public void stop() {
	System.out.println("车停止了");

	}

}

interface Car {
	void start();
	void run();
void stop();
}
posted @ 2018-07-22 22:25  hirampeng  阅读(818)  评论(0编辑  收藏  举报