java进程间通信的方式_进程间通信方式总结

前言

进程间的通信方式,其实我们一直在用它,但是我们都不会去注意它。如果碰到面试官问你知道多少种进程间的通信方式,估计很多人都会有点懵。今天我们就来总结下进程间的通信方式有哪些。

管道

管道,英文为pipe。这是一个我们在学习Linux命令行的时候就会引入的一个很重要的概念。它的发明人是道格拉斯.麦克罗伊,这位也是UNIX上早期shell的发明人。他在发明了shell之后,发现系统操作执行命令的时候,经常有需求要将一个程序的输出交给另一个程序进行处理,也因此,管道应运而生了。

管道可以分为两类:匿名管道和命名管道。

常见的Linux命令 "|" 其实就是匿名管道,表示把一个进程的输出传输到另外一个进程,如:

echo "Happyjava" | awk -F 'j' '{print $2}'

# 输出 ava

另外,我们可以通过 mkfifo 命令创建一个命名管道,如:

mkfifo pipe

一个进程往管道输入数据,则会阻塞等待别的进程从管道读取数据:

ae39fb1839b964cec2663bd981d33afc.png

如果我另外一个窗口没有执行 cat < pipe 命令,则左边的窗口(echo 'Happyjava' > pipe)会一直阻塞。

消息队列

注意,此消息队列不是我们常用的MQ,如kafka,rabbitmq,rocketmq等。

消息队列提供了一种从一个进程向另一个进程发送一个数据块的方法。 每个数据块都被认为含有一个类型,接收进程可以独立地接收含有不同类型的数据结构。我们可以通过发送消息来避免命名管道的同步和阻塞问题。但是消息队列与命名管道一样,每个数据块都有一个最大长度的限制。

使用消息队列进行进程间通信,可能会收到数据块最大长度的限制约束等,这也是这种通信方式的缺点。如果频繁的发生进程间的通信行为,那么进程需要频繁地读取队列中的数据到内存,相当于间接地从一个进程拷贝到另一个进程,这需要花费时间。

共享内存

共享内存这个通信方式就可以很好着解决拷贝所消耗的时间了。系统加载一个进程的时候,分配给进程的内存并不是实际物理内存,而是虚拟内存空间。那么我们可以让两个进程各自拿出一块虚拟地址空间来,然后映射到相同的物理内存中,这样,两个进程虽然有着独立的虚拟内存空间,但有一部分却是映射到相同的物理内存,这就完成了内存共享机制了。

信号量

共享内存最大的问题是什么?没错,就是多进程竞争内存的问题,就像类似于我们平时说的线程安全问题。如何解决这个问题?这个时候我们的信号量就上场了。

信号量的本质就是一个计数器,用来实现进程之间的互斥与同步。例如信号量的初始值是 1,然后 a 进程来访问内存1的时候,我们就把信号量的值设为 0,然后进程b 也要来访问内存1的时候,看到信号量的值为 0 就知道已经有进程在访问内存1了,这个时候进程 b 就会访问不了内存1。所以说,信号量也是进程之间的一种通信方式。

Socket

这个就是我们一直在用的进程间的通信方式了,如我们的微信APP跟微信服务器通信,其实就是使用的Socket套接字进行通信的。

总结

这里总结下,进程(Linux)间的通信方式有:

1、管道

2、消息队列

3、共享内存

4、信号量

5、Socket

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java进程间通信可以通过多种方式实现。其中一种常用的方式是使用Java的RMI(远程方法调用)机制。RMI是一种用于实现远程过程调用(RPC)的Java API,它能够直接传输序列化后的Java对象和支持分布式垃圾收集。RMI的实现依赖于Java虚拟机(JVM),因此它只支持从一个JVM到另一个JVM的调用,可以看作是RPC的Java版本。\[2\] 除了RMI,还有其他一些进程间通信方式,包括数据传输、资源共享、通知事件和进程控制。数据传输是指一个进程需要将它的数据发送给另一个进程;资源共享是指多个进程之间共享同样的资源;通知事件是指一个进程需要向另一个或一组进程发送消息,通知它(它们)发生了某种事件;进程控制是指有些进程希望完全控制另一个进程的执行,例如Debug进程,控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态改变。这些方式可以根据具体的需求选择合适的方式来实现进程间通信。\[3\] #### 引用[.reference_title] - *1* [Java进程通信](https://blog.csdn.net/kking_edc/article/details/108338473)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Java通信方式总结](https://blog.csdn.net/qq_38233258/article/details/123615724)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值