RPC和IPC

RPC和IPC

什么是RPC

RPC(Remote Procedure Call)即远程过程调用,它是一种通过网络从远程计算机程序上请求服务,在不需要了解底层网络技术的协议下,即可获取计算机进程中的数据。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。

RPC在OSI网络通信7层模型中,位于传输层与应用层之间,即位于会话层:

RPC实现模式,就是我们常说的C/S结构,引用百度百科的定义:

RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息到达为止。当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用进程接收答复信息,获得进程结果,然后调用执行继续进行。

简而言之:客户端能向服务端发送若干个进程请求,服务端根据发送的进程参数依次返回对应的计算结果。RPC可以说客户端调用服务端的接口的过程,是面向接口的编程。

RPC在Android中咋样体现的,我们看看官方的解释RPC与IPC的关系

Android 利用远程过程调用 (RPC) 提供了一种进程间通信 (IPC) 机制,通过这种机制,由 Activity 或其他应用组件调用的方法将(在其他进程中)远程执行,而所有结果将返回给调用方。 这就要求把方法调用及其数据分解至操作系统可以识别的程度,并将其从本地进程和地址空间传输至远程进程和地址空间,然后在远程进程中重新组装并执行该调用。 然后,返回值将沿相反方向传输回来。 Android 提供了执行这些 IPC 事务所需的全部代码,因此您只需集中精力定义和实现 RPC 编程接口即可。

要执行 IPC,必须使用 bindService() 将应用绑定到服务上。

也就是说,RPC在的Android具体体现,是依赖 bindService()的方式,在onBind方法将服务端的计算结果返回给客户端(Activity等组件)的过程。

什么是IPC

IPC 即 Inter-Process Communication (进程间通信),是指进程间数据交互的过程。

Android底层是基于Linux,而Linux基于安全考虑,是不允许两个进程间直接操作对方的数据,这就是进程隔离

在Linux系统中,虚拟内存机制为每个进程分配了线性连续的内存空间,操作系统将这种虚拟内存空间映射到物理内存空间,每个进程有自己的虚拟内存空间,进而不能操作其他进程的内存空间,每个进程只能操作自己的虚拟内存空间,只有操作系统才有权限操作物理内存空间.进程隔离保证了每个进程的内存安全,但是在大多数情形下,不同进程间的数据通讯是不可避免的,因此操作系统必须提供跨进程通信机制。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
IPC(Inter-Process Communication,进程间通信)是一种用于不同进程间传递消息和共享数据的机制。在多进程系统中,各个进程之间需要相互通信来协调工作和共享资源。IPC提供了一系列的通信方式,比如管道、消息队列、共享内存、信号量等,可以方便地实现进程间的数据传输和同步。 RPC(Remote Procedure Call,远程过程调用)是一种分布式系统中的通信机制,它允许一台计算机上的程序能够调用另一台计算机上的过程(即函数)而不需要了解底层的网络细节。RPC通过封装远程调用的细节,使得各个计算机节点之间的通信变得简单和透明。 微内核是操作系统设计的一种架构风格,其核心思想是将操作系统划分为多个小的、独立的模块,把核心功能和最基本的服务放在内核中,而将其他的功能移至用户态。这种设计可以提高操作系统的可扩展性、可维护性和安全性。微内核架构中的核心服务包括进程管理、内存管理、文件系统等,而其他功能如设备驱动、网络协议等则放在用户态运行。 在这三个概念中,IPCRPC都是用于实现进程间通信的机制,不同之处在于IPC主要用于同一台计算机上的多个进程之间的通信,而RPC则主要用于跨网络的不同计算机之间的通信。微内核则是一种操作系统的设计思想,与IPCRPC有关系,因为它们都涉及到各个模块之间的通信和交互。 可以说,IPCRPC是实现微内核设计思想的基础和重要组成部分,它们为微内核架构提供了一种灵活和可扩展的通信方式,使得不同的模块可以相互交互,从而实现了操作系统的各种功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时代我西

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值