进程间通信

简介: 1.无名管道 int pipe(int pipefd[2]);参数:@pipefd 获得操作管道的文件描述符 返回值:成功返回0, 失败返回-1 特点:.
1.无名管道 
int pipe(int pipefd[2]);
参数:
@pipefd 获得操作管道的文件描述符 
返回值:
成功返回0, 失败返回-1 

特点:
<1>.pipefd[0] 读管道文件描述符 ,pipefd[1] 写管道文件描述符 
<2>.只能亲缘关系间进程通信(亲缘关系进程存在数据拷贝)

练习:
父进程向管道中输入数据,子进程从管道中读取数据,然后输出 
当输入"quit"的时候,父子进程结束
----------------------------------------------------------------------------
管道读写规则:

<1>写端存在,读管道 
   管道中有数据,读取实际的数据,如果没有数据,读则阻塞 

<2>写端不存在,读管道   
   管道中有数据,读取实际的数据,如果管道中没有数据,读不阻塞,返回 0 

<3>读存在,写管道 
   管道空闲的时候,写入数据,管道满的时候,写阻塞 

<4>读端不存在,写管道 
   此时写管道没有意义,内核会发送SIGPIPE杀死写管道的进程
----------------------------------------------------------------------------

2.有名管道 

特点:
<1>可以实现任意进程间通信 
<2>在文件系统存在名字,是管道文件,不占用磁盘空间 

(1)创建有名管道文件 
int mkfifo(const char *pathname, mode_t mode);

(2)打开有名管道文件 

[1]只读方式打开有名管道文则阻塞,直到另一端以写的方式打开
[2]只写方式打开有名管道文则阻塞,直到另一端以读的方式打开

(3)通过read/write读写有名管道 

注意:有名管道读写规则遵从无名管道的读写规则

练习:
A 进程和B进程聊天
相关文章
|
存储 并行计算 算法
C++进程间通信之共享内存
C++进程间通信之共享内存
797 0
|
5月前
|
消息中间件 负载均衡 安全
进程间通信
数据传输:一个进程需要将它的数据发送给另一个进程资源共享:多个进程之间共享同样的资源。通知事件:一个进程需要向另一个或一组进程发送消息,通知它(它们)发生了某种事件(如进程终止时要通知父进程)。进程控制:有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态改变。进程间通信的本质:让不同的进程先看到同一份资源,但是这份资源不能由双方进程提供,而通常是由操作系统所提供!
39 9
进程间通信
|
存储 消息中间件 Linux
IPC(进程间通信)(上)
IPC(进程间通信)
80 0
|
API
IPC(进程间通信)(下)
IPC(进程间通信)(下)
57 0
|
Unix
进程间通信(一)
进程间通信
71 0
|
消息中间件
进程间通信(非常实用)
进程间通信(非常实用)
|
Linux
2.10~2.29 进程间通信(下)
2.10~2.29 进程间通信
109 0
2.10~2.29 进程间通信(下)
|
Linux
2.10~2.29 进程间通信(上)
2.10~2.29 进程间通信
90 0
2.10~2.29 进程间通信(上)
|
开发者
进程间通信 | 学习笔记
快速学习进程间通信,介绍了进程间通信系统机制, 以及在实际应用过程中如何使用。