IPC和RPC的区别

IPC:(Inter Process Communication )跨进程通信

这个概念泛指进程之间任何形式的通信行为,是个可以拿来到处套的术语。它不仅包括各种形式的消息传递,还可以指共享资源,以及同步对象[mutex 或者其他类似的东西,即确保安全的并发访问共享资源(也就是防止两个或两个以上的对象同事对同一个数据成员进行修改,从而导致数据被破坏,或者竞争条件下同事读/写数据而导致错误的情况发生)]的东西。

RPC:(Reomote Procedure Call) 远程过程调用

特指一种隐藏了过程调用时实际通信细节的IPC方法。客户端将调用一个本地方法,而这个本地方法则是负责透明的与远程服务端进行过程间通信。这个本地方法会讲相关参数顺序打包到一个消息中,然后把这个消息发送给服务端提供的方法,服务端的方法会从消息中解出序列化发出来的参数,然后执行,最后仍以同样的方式将方法的返回值发送给客户端。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值