被代理对象的接口
package JdkCglib;
/**
* Code by langlang on 2020/3/27
*/
public interface Produce {
public void produce();
public void sell(Float money);
}
被代理对象:
package JdkCglib;
/**
* Code by langlang on 2020/3/27
*/
public class Producer implements Produce{
@Override
public void produce() {
System.out.println("生产商品");
}
@Override
public void sell(Float money) {
System.out.println("销售赚了"+money);
}
}
动态代理
package JdkCglib;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
/**
* Code by langlang on 2020/3/27
*/
public class JdkCglib {
public static void main(String[] args) {
final Producer producer = new Producer();
//首先获取到代理对象
/**
* @Description:
*
* 动态代理的特点:
* 不修改源码的基础上对代码进行增强
*
* 注意事项:
* 1.由于invicationHander是内部类的实现,用到的producer需要是finnal类型的。
* 2.jdk动态代理有三个参数,
* 2.1 classloader 这个是被代理对象,
* 2.2 interfacer 这是被代理对象的所有接口方法,让代理对象拥有与被代理对象具有相同的方法
* 2.3 invocationHandler 用于增强代理的代码
*
* @auther: langlang
* @date: 19:27 2020/3/27
* @param: [args]
* @return: void
*/
Produce produce = (Produce) Proxy.newProxyInstance(producer.getClass().getClassLoader(), producer.getClass().getInterfaces(), new InvocationHandler() {
@Override
/**
* @Description:
*
* @auther: langlang
* @date: 19:30 2020/3/27
* @param: [proxy, method, args]
* proxy 是被代理对象的引用
* method 是被代理对象当前执行的方法,本案例是后面动态代理类的sell方法
* args 是当前执行方法中的所有参数
* @return: java.lang.Object 和被代理对象的当前执行方法有相同的返回值
*/
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
Object resultvalue = null;
Float money = (Float) args[0];
if (method.getName() == "sell") {
resultvalue = method.invoke(producer, money * 0.8f);
}
return resultvalue;
}
});
produce.sell(1000f);
}
}