静态代理 Java实现

静态代理:

让代理类代被代理类完成一些“非业务”代码,核心业务代码还是交给被代理者自己完成。

 

例如:给所有方法都增加一个功能,统计该方法的运行时间

 

代理模式:

1、主题接口

2、被代理类

3、代理类

public class TestStatticProxy {
	public static void main(String[] args) {
		// new UserDaoImpl()被代理对象
		// new UserdaoProxy(xx)是代理对象
		UserDao ud = new UserDaoProxy(new UserDaoImpl());
		ud.delete();
	}
}
// 1、主题接口
interface UserDao{
	void insert();
	void delete();
	void update();
	void select();
}
// 2、被代理类
class UserDaoImpl implements UserDao {
	
	@Override
	public void insert() {
		System.out.println("添加用户");
	}

	@Override
	public void delete() {
		System.out.println("删除用户");		
	}

	@Override
	public void update() {
		System.out.println("修改用户");		
	}

	@Override
	public void select() {
		System.out.println("查询用户");		
	}
}
// 3、代理类
//(1)和代理类必须实现同样的主题接口
//(2)因为要把核心业务代码交还给被代理者完成,因此,需要在代理类中,保存(持有)被代理者对象的引用
class UserDaoProxy implements UserDao {
	private UserDao target;

	public UserDaoProxy(UserDao target) {
		super();
		this.target = target;
	}

	@Override
	public void insert() {
		long start = System.currentTimeMillis();
		System.out.println("开始执行insert方法");
		// 执行真正的业务代码
		target.insert();
		
		long end = System.currentTimeMillis();
		System.out.println("结束执行insert方法");
		System.out.println("耗时" + (end - start));
	}

	@Override
	public void delete() {
		long start = System.currentTimeMillis();
		System.out.println("开始执行delete方法");
		// 执行真正的业务代码
		target.delete();
		
		long end = System.currentTimeMillis();
		System.out.println("结束执行delete方法");
		System.out.println("耗时" + (end - start));		
	}

	@Override
	public void update() {
		long start = System.currentTimeMillis();
		System.out.println("开始执行update方法");
		// 执行真正的业务代码
		target.update();
		
		long end = System.currentTimeMillis();
		System.out.println("结束执行update方法");
		System.out.println("耗时" + (end - start));			
	}

	@Override
	public void select() {
		long start = System.currentTimeMillis();
		System.out.println("开始执行select方法");
		// 执行真正的业务代码
		target.select();
		
		long end = System.currentTimeMillis();
		System.out.println("结束执行select方法");
		System.out.println("耗时" + (end - start));			
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Java静态代理和动态代理的介绍和示例: 静态代理静态代理是在编译期间就已经确定代理类的代码,需要为每一个被代理的类编写一个代理类。静态代理的优点是简单易懂,缺点是需要手动编写代理类,当被代理的类增加方法时,代理类也需要相应地修改。 示例代码: 假设有一个接口`Subject`和它的实现类`RealSubject`,我们需要为`RealSubject`类创建一个代理类`ProxySubject`,并在代理类中调用`RealSubject`类的方法。 ```java // 接口 public interface Subject { void request(); } // 实现类 public class RealSubject implements Subject { @Override public void request() { System.out.println("RealSubject request"); } } // 代理类 public class ProxySubject implements Subject { private RealSubject realSubject; public ProxySubject(RealSubject realSubject) { this.realSubject = realSubject; } @Override public void request() { System.out.println("ProxySubject request"); realSubject.request(); } } // 测试类 public class Test { public static void main(String[] args) { RealSubject realSubject = new RealSubject(); ProxySubject proxySubject = new ProxySubject(realSubject); proxySubject.request(); } } ``` 动态代理: 动态代理是在运行时动态生成代理类的代码,不需要事先知道代理类的代码。Java中的动态代理主要有两种形式,一种是基于接口的动态代理,另一种是基于类的动态代理。其中,基于接口的动态代理使用较为广泛。 示例代码: 假设有一个接口`Subject`和它的实现类`RealSubject`,我们需要为`RealSubject`类创建一个动态代理类,并在代理类中调用`RealSubject`类的方法。 ```java // 接口 public interface Subject { void request(); } // 实现类 public class RealSubject implements Subject { @Override public void request() { System.out.println("RealSubject request"); } } // 动态代理类 public class DynamicProxy implements InvocationHandler { private Object target; public DynamicProxy(Object target) { this.target = target; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("DynamicProxy request"); Object result = method.invoke(target, args); return result; } } // 测试类 public class Test { public static void main(String[] args) { RealSubject realSubject = new RealSubject(); DynamicProxy dynamicProxy = new DynamicProxy(realSubject); Subject proxySubject = (Subject) Proxy.newProxyInstance( realSubject.getClass().getClassLoader(), realSubject.getClass().getInterfaces(), dynamicProxy); proxySubject.request(); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值