进程通信

进程通信是指两个并行进程可以通过互相发送消息进行合作,消息是通过消息缓冲而在进程之间相互传递的。

UNIX系统中的进程间的通讯有两层含义:  

– ---单一进程内部各个模块间的通讯

– ---作为单独单位的各个不同进程间的通讯



前者沿袭了单任务操作系统中的模块通讯方法;

后者必须保证各个进程在通讯过程中互不干扰从而保持其通信的一致性。

UNIX采用的进程通信方式

1) 文件和记录锁定。

为避免两个进程间同时要求访问同一共享资源而引起访问和操作的混乱,在进程对共享资源进行访问前必须对其进行锁定,该进程访问完后再释放。这是UNIX为共享资源提供的互斥性保障。



2)管道。

管道一般用于两个不同进程之间的通信。当一个进程创建一个管道,并调用fork创建自己的一个子进程后,父进程关闭读管道端,子进程关闭写管道端,这样 提供了两个进程之间数据流动的一种方式。



3)FIFO。

FIFO是一种先进先出的队列。它类似于一个管道,只允许数据的单向流动。每个FIFO都有一个名字,允许不相关的进程访问同一个FIFO。因此也成为命名管。



4)消息队列。

UNIX下不同进程之间可实现共享资源的一种机制;UNIX允许不同进程将格式化的数据流以消息形式发送给任意

进程。对消息队列具有操作权限的进程都可以使用msget完成对消息队列的操作控制。通过使用消息类型,进程可以按任何顺序读消息,或为消息安排优先级顺序。



5)信号灯。

作为进程间通讯的一种方法,它不是用于交换大批数据,而用于多进程之间的同步(协调对共享存储段的存取)。



6)共享内存。

通过信号灯实现存储共享(类似“红灯停、绿灯行”)


相关词条:
分布式进程通信  
 
自定义分类:
操作系统
 
贡献者:
中国通信一员
Copyright © 1999-2024 C114 All Rights Reserved | 联系我们 | 沪ICP备12002291号-4