zoukankan      html  css  js  c++  java
  • 理解Android系统的进程间通信原理(一)----RPC中的代理模式

    Android系统中的进程间通信是通过一个轻量级的RPC(Remote Procedure Call远程进程调用)和AIDL(Android Interface Definination Language)规范来生成两个进程之间可以相互访问的代码。其中RPC是以接口方式来实现,客户端与被调用实现之间是通过代理模式来实现的,这些又是以JAVA的RMI和代理模式为理论基础的,若要灵活掌握这个轻量级的解决方案,有必要重新理顺这些基础知识的,这里我们先了解代理模式的相关基础,
    有关代理模式的知识,可以用下面这个思维导图来表示:
    这里以一个代码实例来说明实际运用:
    1、抽象类Role代码
    复制代码
     1 package com.magc.proxy;
    2
    3 /**
    4 * @author magc
    5 *代理角色和真实角色的共同抽象类
    6 */
    7 public abstract class Role {
    8
    9 //作为代理角色和真实角色的共同接口,方便代理角色对外代替真实角色来提供服务
    10 public abstract void service(String user_id);
    11
    12 }
    复制代码
    2、真实角色类RealRole代码
    复制代码
     1 package com.magc.proxy;
    2
    3 /**
    4 * @author magc
    5 * 真实角色类
    6 * 对外是不可访问
    7 *
    8 */
    9 public class RealRole extends Role {
    10
    11 /* (non-Javadoc)
    12 * @see com.magc.proxy.Role#service()
    13 * 提供服务
    14 */
    15 @Override
    16 public void service(String user_id) {
    17 System.out.println("真实角色为你服务……");
    18 }
    19 //验证用户身份
    20 public boolean CheckUser(String user_id)
    21 {
    22 return true;
    23 }
    24
    25 }
    复制代码
    3、代理类ProxyRole代码:
    复制代码
     1 package com.magc.proxy;
    2
    3 /**
    4 * @author magc
    5 * 代理角色类
    6 * 对客户端开发其接口
    7 * 内部可以直接引用真实角色实例,将客户端的请求转给真实角色实例
    8 * 对转发请求的前或者后面可以增加一些额外操作
    9 */
    10 public class ProxyRole extends Role {
    11 private RealRole realrole = null;
    12
    13 /* (non-Javadoc)
    14 * @see com.magc.proxy.Role#service()
    15 */
    16 @Override
    17 public void service(String user_id) {
    18 System.out.println("代理角色为你服务……");
    19 //需要时才去创建真实角色实例
    20 realrole = new RealRole();
    21 //增加额外操作:验证身份
    22 System.out.println("验证身份……");
    23 if(!realrole.CheckUser(user_id))
    24 return;
    25 System.out.println("去找真实角色实例帮忙处理事务……");
    26 realrole.service("magc");
    27
    28 System.out.println("谢谢光临……");
    29 }
    30
    31 }
    复制代码
    4、测试类RoleTest类代码
    复制代码
     1 package com.magc.proxy;
    2
    3 /**
    4 * @author magc
    5 * 代理模式测试类
    6 * 作为客户端去请求调用代理类的接口。
    7 * 客户端只能访问代理类,而不能访问真实角色类
    8 */
    9 public class ProxyTest {
    10
    11 /**
    12 * @param args
    13 */
    14 public static void main(String[] args) {
    15
    16 ProxyRole proxy = new ProxyRole();
    17 proxy.service("magc");
    18 }
    19
    20 }
    复制代码
    运行测试类,控制台输出结果为:
     
    由于时间仓促,错误难免,希望能给大家有所启示,也算是在这里抛砖引玉了,呵呵
  • 相关阅读:
    执行脚本,且以脚本名保存log
    循环读取寄存器(QSFP-DD)并且分别保存log
    shell脚本添加脚本执行时间和当前运行次数current running time
    软件后门种植
    IPC$管道的利用与远程控制
    古典密码-维吉尼亚密码实验
    古典密码之乘法密码
    古典密码之凯撒密码
    密码破解工具Brutus
    ASPack壳脱壳实验
  • 原文地址:https://www.cnblogs.com/senior-engineer/p/4994087.html
Copyright © 2011-2022 走看看