多进程】 【Java基础】java进程间通信的方式

2021-01-08 20:25发布

5条回答
小小李兆佳
2021-01-20 09:38

(1)   管道(PIPE) 
(2)   命名管道(FIFO) 
(3)   信号量(Semphore) 
(4)   消息队列(MessageQueue) 
(5)   共享内存(SharedMemory) 
(6)   Socket

Java如何支持进程间通信。我们把Java进程理解为JVM进程。很明显,传统的这些大部分技术是无法被我们的应用程序利用了(这些进程间通信都是靠系统调用来实现的)。但是Java也有很多方法可以进行进程间通信的。 
除了上面提到的Socket之外,当然首选的IPC(进程间通信)可以使用Rmi(远程方法调用),或者Corba公共对象请求代理体系结构,通用对象请求代理体系结构)也可以。另外Java nio的MappedByteBuffer也可以通过内存映射文件来实现进程间通信(共享内存)。

Java进程间通信可以采用的办法:

Socket/RMI/WEBService/WebServer, 这些都可以实现直接的数据交换 
Database/File, 这些可以实现间接的数据交换   
    
看你的业务是否要求实时, 如果不需要, 用数据库交换比较简单

线程间通信:

可以直接传入共享的变量来实现。

 


一周热门 更多>