动态代理简单来说 就是在不改变原来代码的情况下 增加功能
核心在于代码的书写
下面是一个简单的实例:
Star接口:
public interface Star {
public abstract String sing(String name);
public abstract void dance();
}
Star实现类BigStar
public class BigStar implements Star{
private String name;
private Integer age;
public BigStar() {
}
public BigStar(String name, Integer age) {
this.name = name;
this.age = age;
}
public BigStar(String name) {
this.name = name;
}
@Override
public String sing(String name) {
System.out.println(this.name+"开始唱 :"+name);
return "谢谢";
}
@Override
public void dance() {
System.out.println(this.name+"开始跳舞");
}
/**
* 获取
* @return name
*/
public String getName() {
return name;
}
/**
* 设置
* @param name
*/
public void setName(String name) {
this.name = name;
}
/**
* 获取
* @return age
*/
public Integer getAge() {
return age;
}
/**
* 设置
* @param age
*/
public void setAge(Integer age) {
this.age = age;
}
public String toString() {
return "BigStar{name = " + name + ", age = " + age + "}";
}
}
代理对象Proxy
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class ProxyUtil {
public static Star creatProxy(BigStar bigStar) {
Star estar = (Star) Proxy.newProxyInstance(
/*
* 第一个参数:是类加载器;就是说这里写的是当前类的类加载器 相当于字节码文件转化的
* 第二个参数:是一个数组 里面可以写一个或者多个需要代理的方法类 在这里就是star这个接口
* 第三个参数:是一个执行的东西 就是你要做什么 在这个完成 在这个里就是完成唱歌或者跳舞的前期收钱
* */
ProxyUtil.class.getClassLoader(),
new Class[]{Star.class},
new InvocationHandler() {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
/*
* proxy:
* method:方法
* arg:方法的实参
* */
if ("sing".equals(method.getName())) {
System.out.println("准备话筒,收钱");
} else if ("dance".equals(method.getName())) {
System.out.println("准备场地,收钱");
}
return method.invoke(bigStar, args);
}
});
return estar;
}
}
最后是测试代码:
public class test {
public static void main(String[] args) {
BigStar bigStar = new BigStar("鸡哥");
Star star = ProxyUtil.creatProxy(bigStar);
String sing = star.sing("只因你太美");
System.out.println(sing);
star.dance();
}
}