动态代理的代码
public interface SaleComputer {
public String sale(double money);
public void show();
}
package cn.itcast.proxy;
/*
* 真实类
*/
public class Lenovo implements SaleComputer {
@Override
public String sale(double money) {
System.out.println("花了"+money+"元买了一台联想电脑");
return "联想电脑";
}
@Override
public void show() {
System.out.println("展示电脑...");
}
}
package cn.itcast.proxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class ProxyTest {
public static void main(String[] args) {
//1.创建真实对象
Lenovo lenovo=new Lenovo();
/*
* 三个参数:
* 1.类加载器:真实对象.getClass().getClassLoader()
* 2.接口数组:真实对象.getClass().getInterfaces() 保证代理对象和真实对象实现相同的接口
* 3.处理器;new InvocationHandler(){} 匿名内部类的写法
* 里面是我们核心业务逻辑的处理
*/
//2.动态代理增强lenovo对象
//最终返回的就是代理对象
//因为实现的是相同的接口可以强转成接口类型
//大类型转小类型要强转
SaleComputer proxy_lenovo =(SaleComputer) Proxy.newProxyInstance(lenovo.getClass().getClassLoader(), lenovo.getClass().getInterfaces(), new InvocationHandler() {
/*
* 代理逻辑进行编写的方法:代理对象调用的所有方法都会触发该方法的执行
* 参数:
* 1.proxy:代理对象 这里指的就是:proxy_lenovo
* 2.method:代理对象调用的方法封装为对象
* 3.atgs:代理对象调用方法传递的实际参数
*
*/
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// System.out.println("该方法执行了");
// System.out.println(method.getName());
// System.out.println(args[0]);
//判断是否是sale方法
if(method.getName().equals("sale")) {
//1.增强参数
double money=(double)args[0];
money=money*0.85;
System.out.println("专车接你");
//使用真实对象调用该方法
String obj = (String)method.invoke(lenovo, money);
System.out.println("免费送货");
//2.增强返回值
return obj+"_鼠标垫";
}else {
Object obj = method.invoke(lenovo, args);
return obj;
}
}
});
//2.调用方法
String computer = proxy_lenovo.sale(8000);
System.out.println(computer);
}
}