JDK动态代理中包含一个类和一个接口: 
InvocationHandler接口: 
public interface InvocationHandler { 
public Object invoke(Object proxy,Method method,Object[] args) throws Throwable; 

参数说明: 
Object proxy:指被代理的对象。 
Method method:要调用的方法 
Object[] args:方法调用时所需要的参数

接口IFromService

package com.test.service;

public interface IFromService {

    public void removeService(long serviveid) throws Exception;

    public void modifyService(long serviveid)throws Exception; 

}

接口实现类 FromServieImpl

package com.test.service;

public class FromServieImpl implements IFromService{

    @Override
public void removeService(long serviveid) throws Exception {
// TODO Auto-generated method stub
System.out.println("模拟删除服务ID:"+serviveid);
Thread.currentThread().sleep(20);
} @Override
public void modifyService(long serviveid) throws Exception {
// TODO Auto-generated method stub
System.out.println("模拟修改服务ID:"+serviveid);
Thread.currentThread().sleep(40);
} /**
* 无接口实现类方法
* @param obj
* @throws InterruptedException
*/
public void addService(Object obj) throws InterruptedException{
System.out.println("模拟新增服务:"+obj);
Thread.currentThread().sleep(40);
} }

jdk代理类 FromServiceProxy

package com.test.proxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Date; import com.test.utils.DateTimeUtil; /**
* jdk 动态代理
* @author Administrator
*
*/
public class FromServiceProxy implements InvocationHandler{
private Object target; /**
* 绑定委托类并返回代理类
* @param target
* @return
*/
public Object bind(Object target){
this.target=target;
return Proxy.newProxyInstance(target.getClass().getClassLoader(),target.getClass().getInterfaces(),this);
} /**
* 调用
*/
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// TODO Auto-generated method stub
Object result=null;
Date stdate=new Date();
System.out.println("监测 开始时间:"+DateTimeUtil.dateToStrOfDefaulfFormat(stdate));
result=method.invoke(target, args);
Date eddate=new Date();
System.out.println("监测 结束时间:"+DateTimeUtil.dateToStrOfDefaulfFormat(eddate));
System.out.println(method.getName()+" 执行耗时:"+(eddate.getTime()-stdate.getTime())+" ms"); return result;
} }

测试 TestProxy

package com.test.proxy;

import com.test.service.FromServieImpl;
import com.test.service.IFromService; public class TestProxy { public static void main(String[] args) throws Exception {
System.out.println("==============jdk proxy=================");
FromServiceProxy proxy=new FromServiceProxy();
IFromService service=(IFromService) proxy.bind(new FromServieImpl());
service.removeService(123);
service.modifyService(123);
}
}

输出如下:

==============jdk proxy=================
监测 开始时间:2016-03-24 13:25:48
模拟删除服务ID:123
监测 结束时间:2016-03-24 13:25:48
removeService 执行耗时:54 ms
监测 开始时间:2016-03-24 13:25:48
模拟修改服务ID:123
监测 结束时间:2016-03-24 13:25:48
modifyService 执行耗时:41 ms

Cglib动态代理 
JDK的动态代理机制只能代理实现了接口的类,而不能实现接口的类就不能实现JDK的动态代理,cglib是针对类来实现代理的,他的原理是对指定的目标类生成一个子类,并覆盖其中方法实现增强,但因为采用的是继承,所以不能对final修饰的类进行代理。

cglib代理 FromServiceCglibProxy

package com.test.proxy;

import java.lang.reflect.Method;
import java.util.Date; import org.springframework.cglib.proxy.Enhancer;
import org.springframework.cglib.proxy.MethodInterceptor;
import org.springframework.cglib.proxy.MethodProxy; import com.test.utils.DateTimeUtil; /**
* cglib 动态代理
* @author Administrator
*
*/
public class FromServiceCglibProxy implements MethodInterceptor{ private Object target; /**
* 创建代理对象
* @param target
* @return
*/
public Object getInstance(Object target){
this.target=target;
Enhancer enhancer=new Enhancer();
enhancer.setSuperclass(this.target.getClass());
enhancer.setCallback(this);
return enhancer.create();
} @Override
public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable {
Date stdate=new Date();
System.out.println("监测 开始时间:"+DateTimeUtil.dateToStrOfDefaulfFormat(stdate));
proxy.invokeSuper(obj, args);
Date eddate=new Date();
System.out.println("监测 结束时间:"+DateTimeUtil.dateToStrOfDefaulfFormat(eddate));
System.out.println(method.getName()+" 执行耗时:"+(eddate.getTime()-stdate.getTime())+" ms");
return null;
} }

测试类 TestProxy

package com.test.proxy;

import com.test.service.FromServieImpl;
import com.test.service.IFromService; public class TestProxy { public static void main(String[] args) throws Exception { System.out.println("==============cglib proxy=================");
FromServiceCglibProxy cglib=new FromServiceCglibProxy();
FromServieImpl serviceImpl=(FromServieImpl) cglib.getInstance(new FromServieImpl());
serviceImpl.addService("entity");
}
}

输出如下:

==============cglib proxy=================
监测 开始时间:2016-03-24 13:25:48
模拟新增服务:entity
监测 结束时间:2016-03-24 13:25:48
addService 执行耗时:65 ms

jdk与cglib的动态代理的更多相关文章

  1. JDK 和 CGLib 实现动态代理和区别

    JDK 和 CGLib 实现动态代理和区别 在日常的开发中,Spring AOP 是一个非常常用的功能.谈到 AOP,自然离不开动态代理. 那么,基于 JDK 和 CGLib 如何实现动态代理,他们之 ...

  2. JDK和Cglib实现动态代理实例及优缺点分析

    Spring AOP使用的核心技术是动态代理,说到动态代理就不得不和设计模式中的代理模式联系起来,通过代理模式我们可以对目标类进行功能增强,在某个方法的执行前后增加一些操作,例如计算方法执行效率.打印 ...

  3. JDK和CGLIB生成动态代理类的区别

     关于动态代理和静态代理 当一个对象(客户端)不能或者不想直接引用另一个对象(目标对象),这时可以应用代理模式在这两者之间构建一个桥梁--代理对象. 按照代理对象的创建时期不同,可以分为两种: 静态代 ...

  4. 【4】JDK和CGLIB生成动态代理类的区别

    当一个对象(客户端)不能或者不想直接引用另一个对象(目标对象),这时可以应用代理模式在这两者之间构建一个桥梁--代理对象. 按照代理对象的创建时期不同,可以分为两种: 静态代理:事先写好代理对象类,在 ...

  5. JDK和CGLIB生成动态代理类的区别(转)

     关于动态代理和静态代理 当一个对象(客户端)不能或者不想直接引用另一个对象(目标对象),这时可以应用代理模式在这两者之间构建一个桥梁--代理对象. 按照代理对象的创建时期不同,可以分为两种: 静态代 ...

  6. java面试题之spring aop中jdk和cglib哪个动态代理的性能更好?

    在jdk6和jdk7的时候,jdk比cglib要慢: 在jdk8的时候,jdk性能得到提升比cglib要快很多: 结论出自:https://www.cnblogs.com/xuliugen/p/104 ...

  7. cglib实现动态代理简单使用

    Boss: package proxy.cglib; public class Boss{ public void findPerson() { System.out.println("我要 ...

  8. jdk自带的动态代理

    package com.stone.dp.proxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Met ...

  9. 使用CGLIB实现动态代理

    参考:https://blog.csdn.net/yhl_jxy/article/details/80633194#comments CGLIB动态代理 定义:CGLIB(code genaratio ...

随机推荐

  1. 将Map转换为Java 对象

    public class MapUtil { public static Object convert2Object(Class clazz,Map<String,Object[]> ma ...

  2. CSS3自定义图标

    http://ntesmailfetc.blog.163.com/blog/static/206287061201292631536545/ http://www.zhihu.com/question ...

  3. CMOS和TTL的區別

    TTL電路是晶體管-晶體管邏輯電路的英文縮寫(Transister-Transister-Logic ),是數字集成電路的一大門類.它采用雙極型工藝制造,具有高速度低功耗和品種多等特點. CMOS是: ...

  4. Bit,Bytes,KB,MB,GB,TB,PB,EB,ZB,YB

    Bit,Bytes,KB,MB,GB,TB,PB,EB,ZB,YB 汉字字符 2字节英文字符 1字节中文标点 2字节英文标点 1字节一个字节就是一个八位二进制数啊,2就是00000010,4就是000 ...

  5. Apache安装完服务没有安装的情况

    安装完apache之后(不是按照默认路径安装的,例如是 D:\ )右下方哪个小羽毛图标是没有启动的,左键不好使,而且提示“No services installed”,提示服务器没有被安装.解决方法: ...

  6. 5. c++ 内存管理 C/C++ 内存机制

    参考自:http://blog.csdn.net/wpf_ml/article/details/7759911 1. 内存,Cache,寄存器内存:通常计算机将数据存放在物理内存,cache及寄存器中 ...

  7. dos 下 注册win 组件 ocx 后缀的

    C:\WINDOWS\system32>regsvr32 NTGraph.ocx

  8. Java并发编程:CopyOnWrite容器的实现

    Java并发编程:并发容器之CopyOnWriteArrayList(转载) 原文链接: http://ifeve.com/java-copy-on-write/ Copy-On-Write简称COW ...

  9. GDB错误:Cannot find bounds of current function

    http://blog.csdn.net/zoomdy/article/details/17249165 mingdu.zheng <at> gmail <dot> com 使 ...

  10. 写自己的WPF样式 - 按钮

    做一个后台管理小程序,据说WPF的界面比较"炫",于是选择使用WPF来开发.既然用了WPF当然需要做好看点了,于是稍微研究了下WPF的样式,废话不多说下面开始自定义一个按钮样式: ...