package com.gaoji.member;
//接口类
public interface Person {
void showName();
void showAge();
void showSex();
}package com.gaoji.member;
//实现类
public class PersonImpl implements Person{
@Override
public void showName() {
// TODO Auto-generated method stub
System.out.println("我叫张三");
}
@Override
public void showAge() {
// TODO Auto-generated method stub
System.out.println("今年十八岁");
}
@Override
public void showSex() {
// TODO Auto-generated method stub
System.out.println("我是男孩子");
}
}package com.gaoji.member;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Date;
//代理类
public class InvocationHandlerImpl implements InvocationHandler{
// 目标对象
private Object target;
/** * 构造方法 * @param target 目标对象 */
public InvocationHandlerImpl(Object target) {
super();
this.target = target;
}
/** * 获取目标对象的代理对象 * @return 代理对象 */
public Object getProxy() {
return Proxy.newProxyInstance(Thread.currentThread().getContextClassLoader(),
target.getClass().getInterfaces(), this);
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// 在目标对象的方法执行之前简单的打印一下 proxy:类加载器、method:接口
System.out.println(method.getName()+"开始"+new Date());
// 执行目标对象的方法
Object result = method.invoke(target, args);
// 在目标对象的方法执行之后简单的打印一下
System.out.println(method.getName()+"结束了"+new Date());
return result;
}
}package com.gaoji.member;
/*驱动类 * 高内聚,低耦合 1.非业务逻辑代码冗余 2.维护困难 */
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
//动态代理
// 项目测试时,需要日写志
public class MainTest {
public static void main(String[] args) {
/*Person p=new PersonImpl(); p.showName(); p.showAge();*/
Person p=new PersonImpl();
InvocationHandlerImpl handler =new InvocationHandlerImpl(p);
Person p1=(Person) handler.getProxy();//代理类
p1.showAge();
p1.showName();
p1.showSex();
}
}showAge开始Fri May 10 21:04:34 GMT+08:00 2019
今年十八岁
showAge结束了Fri May 10 21:04:34 GMT+08:00 2019
showName开始Fri May 10 21:04:34 GMT+08:00 2019
我叫张三
showName结束了Fri May 10 21:04:34 GMT+08:00 2019
showSex开始Fri May 10 21:04:34 GMT+08:00 2019
我是男孩子
showSex结束了Fri May 10 21:04:34 GMT+08:00 2019发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/106725.html原文链接:https://javaforall.cn