Spring代理模式(jdk动态代理模式)

有动态代理和静态代理:

静态代理就是普通的Java继承调用方法。

Spring有俩种动态代理模式:jdk动态代理模式 和 CGLIB动态代理

jdk动态代理模式:

Spring代理模式(jdk动态代理模式)

代码实现:

Spring代理模式(jdk动态代理模式)

房东出租房子的方法(继承下面出租房子的接口):

package com.bjsxt.proxy1;

public class FangDong implements LetRoom {
@Override
public void zufang() {
System.out.println("出租学院东校区对面和顺小区A401");
}
}

出租房子的方法(接口)

package com.bjsxt.proxy1;

public interface LetRoom {

    public void zufang();
}

核心jdk代理(模拟中介卖房)

package com.bjsxt.proxy1;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy; public class ZhongJie implements InvocationHandler { private LetRoom lr; public void setLr(LetRoom lr) {
this.lr = lr;
} //执行改方法就会动态产生代理对象
public Object getProxy(){
/**
*
* 参数一:保证类型是ClassLoader
*
* 参数二:接口的class数组
*
* 参数三:参数类型是InvocationHandler即可
*
* */ Object o = Proxy.newProxyInstance(ZhongJie.class.getClassLoader(), new Class[]{LetRoom.class}, this); return o; } @Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
/**
* proxy:代理对象--中介
*
* method:代理对象中的方法
*
* args:参数--null;
*
* */
System.out.println("收取介绍费100元"); Object invoke = method.invoke(lr, args); System.out.println("收取管理费500元"); return invoke;
}
}

测试类:

package com.bjsxt.proxy1;

public class Test {
public static void main(String[] args) {
ZhongJie zj=new ZhongJie();
zj.setLr(new FangDong());
LetRoom proxy =(LetRoom) zj.getProxy();
proxy.zufang();
// Util.writeProxyClassToHardDisk("E:/$Proxy11.class",new FangDong().getClass().getInterfaces() );
}
}

测试结果:

Spring代理模式(jdk动态代理模式)

上一篇:一次数组越界的bug经历


下一篇:.NET 下 模拟数组越界