java 代理

本文对比了静态代理与动态代理的不同之处,详细介绍了两者的设计模式及实现方式,并通过实例展示了如何使用这两种代理模式进行方法拦截。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

动态代理与静态代理的区别。

静态代理这个模式本身有个大问题,如果类方法数量越来越多的时候,代理类的代码量是十分庞大的。所以引入动态代理来解决此类问题。

接口:

/**
 * @author liuh
 * @date 2018年5月28日 上午10:15:40
 */
public interface IUser {

	 // 查询账户
    public void queryAccount();  
  
}

接口实现:

/**
 * @author liuh
 * @date 2018年5月28日 上午10:16:12
 */
public class UserImpl implements IUser {

	@Override
	public void queryAccount() {
		System.out.println("查看账户...");
	}
}
  1. 静态代理:
/**
 * @author liuh
 * @date 2018年5月28日 上午10:16:47
 */
public class UserProxy implements IUser {

	private IUser iUser;

	public UserProxy(IUser iUser) {
		this.iUser = iUser;
	}

	@Override
	public void queryAccount() {
		// TODO Auto-generated method stub
		System.out.println("查看账户前--先登陆账户");
		iUser.queryAccount();
	}

	public static void main(String[] args) {
		IUser co = new UserImpl();
		UserProxy coProxy = new UserProxy(co);
		coProxy.queryAccount();
	}

}
  1. 动态代理 有实现类:
/**
 * @note 接口实现类 动态代理 
 * @author liuh 
 * @date 2018年5月28日 上午10:16:47
 */
public class UserProxy implements InvocationHandler {

	private Object target;

	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 {
		Object result = null;
		// TODO Auto-generated method stub
		System.out.println("预处理操作——————");
		// 调用真正的业务方法
		result = method.invoke(target, args);
		System.out.println("调用后处理——————");
		return result;
	}

	public static void main(String[] args) {
		IUser iUser=(IUser)new UserProxy().bind(new UserImpl());
		iUser.queryAccount();
	}

}
  1. 动态代理 无实现类
/**
 * @note 接口无实现类 动态代理
 * @author liuh
 * @date 2018年5月28日 上午10:16:47
 */
public class UserProxy implements InvocationHandler {

	public Object bind(Class<?> target) {
		return Proxy.newProxyInstance(target.getClassLoader(), new Class[] { target }, this);
	}

	@Override
	public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
		Object result = null;
		// TODO Auto-generated method stub
		System.out.println("预处理操作——————");
		// 接口的抽象方法实现
		if(method.getName().equals("queryAccount")) {
			result = run(method,args);
		}
		System.out.println("调用后处理——————");
		return result;
	}

	public Object run(Method method, Object[] args) {
		// TODO
		System.out.println("查看账户...");
		return null;
	}

	public static void main(String[] args) {
		// 通过此语句得到动态生成 的class 文件
		System.getProperties().put("sun.misc.ProxyGenerator.saveGeneratedFiles", "true"); 
		IUser iUser = (IUser) new UserProxy().bind(IUser.class);
		iUser.queryAccount();
	}

}

 

转载于:https://my.oschina.net/liuh1988/blog/1820620

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值