首先上一个图:
下面贴上代码
1.需要被代理的接口
public interface LoginService {
public void say();
public void say(String name);
public void eat(String food);
public String speak(String name);
}
2.需要被代理的接口实现类
public class LoginServiceImpl implements LoginService{
public void say() {
System.out.println("你好");
}
public void say(String name) {
System.out.println("你好:"+ name);
}
public void eat(String food) {
System.out.println("吃饭了,吃的是:" + food);
}
public String speak(String name) {
return "hello" + name;
}
}
3.动态代理类
public class ProxyDemo {
public static void main(String[] args) {
// 构造一个LoginService接口的动态代理对象
LoginService o = (LoginService) Proxy.newProxyInstance(LoginService.class.getClassLoader(), new Class<?>[]{LoginService.class},new MyInvocationHandler());
// 然后调用动态代理对象上的方法,这些方法一定是接口中已经定义的方法
// 但是,这些方法执行的逻辑,并不在LoginService实现类LoginServiceImpl中,而是在MyInvocationHandler的invoke方法中
o.eat("三明治");
String speak = o.speak("张三");
System.out.println(speak);
o.say();
o.say("铁蛋儿");
}
}
4.动态代理类中Proxy.newProxyInstance中第三个需要传入的参数:即InvocationHandler接口的实现类
public class MyInvocationHandler implements InvocationHandler {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
if (method.getName().equals("eat")) {
System.out.println("我一点都不喜欢吃" + args[0]);
}
if (method.getName().equals("speak")) {
String speak = new LoginServiceImpl().speak((String) args[0]);
return speak;
}
if (method.getName().equals("say")) {
if (method.getParameterTypes().length > 0) {
System.out.println("我爱死" + args[0] + "了");
} else {
System.out.println("你调的是say()方法,但是我就打印这句话了");
}
}
return null;
}
}
动态代理涉及:接口
还有可能会用到反射,以及匿名内部类,匿名内部类就是实现接口的另一种方式,具体可以参见笔记。
另外附上我参考的博客:
xiaojin21cen的博客