以前の静的プロキシモードに基づいて動的プロキシモードに変更されました
ケースワン
1.インターフェイス
//租房
public interface Rent {
public void rent();
}
2.実際のキャラクター
//房东
public class Host implements Rent {
public void rent(){
System.out.println("房东出租房子!");
}
}
3.プロキシクラスの自動生成InvocationHandlerはプロキシクラス
を自動的に生成し、このクラスを実装するクラスを作成します
public class ProxyInvocationHandler implements InvocationHandler {
//被代理的按口
private Rent rent;
public void setRent(Rent rent) {
this.rent = rent;
}
//生成得到代理类
public Object getProxy() {
return Proxy.newProxyInstance(this.getClass().getClassLoader(), rent.getClass().getInterfaces(), this);
}
//处理代理实例。并返回结果
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//动态代理的本质,就是使用反射机制实现!
seeHouse();
Object result = method.invoke(rent, args);
fare();
return result;
}
public void seeHouse() {
System.out.println("中介带看房子");
}
public void fare() {
System.out.println("收取中介费");
}
}
4.顧客アクセス
public class Client {
public static void main(String[] args) {
//真实角色
Host host = new Host();
//代理角色:现在没有
ProxyInvocationHandler pih = new ProxyInvocationHandler();
//通过调用程序处理角色米处理我们要调用的按口对象!
pih.setRent(host);
Rent proxy = (Rent) pih.getProxy();//这里的proxy就是动态生成的,我们并没有写
proxy.rent();
}
}
事例2
1.インターフェイス
public interface UserService{
void add();
void delete();
void update();
void query();
}
2.実際のキャラクター
public class UserServiceImpl implements UserService {
public void add() {
System.out.println("增加了一个用户");
}
public void delete() {
System.out.println("删除了一个用户");
}
public void update() {
System.out.println("修改了一个用户");
}
public void query() {
System.out.println("查询了一个用户");
}
}
3.プロキシクラスを自動的に生成する
//等我们会用这个类, 自动生成代理类!
public class ProxyInvocationHandler implements InvocationHandler {
//被代理的按口
private Object target;
public void setTarget(Object target) {
this.target = target;
}
//生成得到代理类
public Object getProxy() {
return Proxy.newProxyInstance(this.getClass().getClassLoader(), target.getClass().getInterfaces(), this);
}
//处理代理实例。并返回结果
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//动态代理的本质,就是使用反射机制实现
log(method.getName());//反射得到实现的方法的名字
Object result = method.invoke(target, args);
return result;
}
public void log(String msg) {
System.out.println("执行了" + msg + "方法");
}
}
4.顧客アクセス
public class Client {
public static void main(String[] args) {
//真实角色
UserServiceImpl userService = new UserServiceImpl();
//代理角色,不存在
ProxyInvocationHandler pih = new ProxyInvocationHandler();
pih.setTarget(userService);
//动态生成代理类
UserService proxy = (UserService) pih.getProxy();
proxy.query();
}
}
まとめ
動的エージェントの利点:
- 一部の公共事業に注意を払う必要なく、実際のキャラクターの操作をより純粋にすることができます
- 公衆は代理人の役割に引き渡され、事業の分割を実現します
- 公共サービス拡大時の便利な集中管理
- 動的エージェントクラスエージェントクラスは、一般的にビジネスのクラスに対応するインターフェースです
- 動的プロキシクラスは、同じインターフェイスが実装されている限り、複数のクラスをプロキシできます。