Yarn核心——RPC(1) 动态代理

RPC的动态代理实现

(1) 定义协议

public interface Person {
    void walk();
    void sayHello();
}

(2) 实现协议

public class MyInvocationHandler implements InvocationHandler {
    /*
    * 执行动态代理对象的所有方法时,都会被替换成执行如下的invoke方法
    * proxy: 代表动态代理对象
    * method: 代表正在执行的方法
    * args: 代表实参
    *
    * */
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("---正在执行的方法:"+method);
        method.invoke(proxy,args);
        if (args != null){
            System.out.println("--传入的实参为:");
            for (Object arg:args){
                System.out.println(arg);
            }
        }else{

        }
        return null;
    }
}

(3) 测试

public class ProxyText {
    public static void main(String[] args) throws Exception{
        InvocationHandler handler = new MyInvocationHandler();
        Person p =(Person) Proxy.newProxyInstance(Person.class.getClassLoader(),
                new Class[]{Person.class},handler);
        // 动态代理对象的walk和sayhello
        p.walk();
        p.sayHello();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值