文档章节

Java动态代理

Zero零_度
 Zero零_度
发布于 2016/03/29 11:32
字数 349
阅读 21
收藏 0

Java动态代理

package com.server;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

//InvocationHandler是一个监听器, 当代理对象调用任何方法的时候都会经过InvocationHandler的invoke方法
public class ProxyHelper implements InvocationHandler {

    private TimerService target;
    
    public void setTarget(TimerService target) {
        this.target = target;
    }
    
    @Override
    // proxy 是拦截到的代理对象    args是方法参数
    public Object invoke(Object proxy, Method method, Object[] args)
            throws Throwable {
        System.out.println("执行" + method.getName() + "方法前,记录日志。。。");
        method.invoke(target, args);
        System.out.println("执行" + method.getName() + "方法后,记录日志。。。");
        return null;
    }
}

写法二:

package com.server;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

// InvocationHandler是一个监听器, 当代理对象调用任何方法的时候都会经过InvocationHandler的invoke方法
public class ProxyHelper implements InvocationHandler {
    
    private Object target;   // 先备份目标
    
    public Object newProxyInstance(Object target){
        this.target = target;  // *****
        return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), this);
    }
    
    // proxy.a();
    public Object invoke(Object arg0, Method arg1, Object[] arg2)
            throws Throwable {
        System.out.println("代理对象调用方法了....调用的是"+arg1.getName());
        System.out.println(arg1.getName()+"开始执行, 开始记录日志");
        // target.a(参数);
        // arg0 是拦截到的代理对象
        try{
        arg1.invoke(target, arg2);
        }catch(Exception e){
            System.out.println(arg1.getName()+"出现异常, 开始记录日志");
        }
        System.out.println(arg1.getName()+"执行完毕");
        return null;
    }
    
    
    // 之前切面: 打开session  启动事务
    // dao 功能执行                   --------------------> 异常切面
    // 之后切面: 提交事务 关闭session

}

调用:

package com.server;

import java.lang.reflect.Proxy;

public class Client {
    
    public static void main(String[] args) {
        TimerService target = new TimerBean();        // 这里可以利用Spring的注入
        ProxyHelper helper = new ProxyHelper();
        helper.setTarget(target);
        TimerService service = (TimerService)Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), helper);
        service.b();
    }
    
}


© 著作权归作者所有

共有 人打赏支持
Zero零_度
粉丝 67
博文 1245
码字总数 252866
作品 0
程序员

暂无文章

解读|TARS开源项目发布Go语言版本

导语:近日,Tars 开源项目在上海发布并开源了 Go 语言版本,其性能与 C++ 版本相当,比 gRPC 的性能高 5 倍。 ——编者 Tars 是腾讯开源的一款微服务框架,它于去年 4 月份开源,并于今年 ...

腾讯开源
14分钟前
0
0
redis-list

列表用来存储多个有序的字符串,列表中元素是可以重复的,最多可以存储2^32-1个元素 常用命令: lrange key start end 获取指定范围内的元素列表,索引从0开始 0,-1取出所有的元素 lindex k...

拐美人
30分钟前
0
0
AOSP Build System —— Soong

Soong Soong is the replacement for the old Android make-based build system. It replaces Android.mk files with Android.bp files, which are JSON-like simple declarative descriptio......

雪落青山
47分钟前
1
0
Unity C# lock关键字的坑

Unity 5.6 环境下的 lock关键字,在特定的多线程环境下会死锁 崩溃 其中一种情况: 异步socket 操作,由于内部是一个线程池回调的异步回调,操作同一个对象时 lock关键字会概率出现死锁 闪退...

梦想游戏人
59分钟前
1
0
简单的svm例子

数据来源:https://github.com/oumiga1314/Coursera-ML-AndrewNg-Notes/blob/master/code/ex6-SVM/data/ex6data1.mat import pandas as pd import numpy as np import scipy.io as sio impor......

南桥北木
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部