c语言程序实现进程的管道通信,C 进程间通信–命名管道通信代码实现及其原理图示…

  • Post author:
  • Post category:其他


在将这个题目之前大家需要了解几个概念:

进程: 我们可以先看进程的定义:进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础;在当总结起来就是:进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。

程序和进程之间的关系又是什么样子呢?一般情况下,我们启动一个程序系统就会启动一个(有时候会有多个进程)。所以程序是静态的代码,进程是程序运行时产生的活动。启动一个程序时可以产生一个或若干个进程。进程实际上是程序当中正在执行的代码(可能只是整个程序的一部分代码)所产生的一个活动对象。

a0af07aeb37a4864f5995e40ae784e83.png

我们可以通过任务管理器查看与管理进程。

线程间我们知道可以通过变量或者公共资源来进行数据交换,那么进程之间呢?进程间通讯一般有这几种方式:管道( pipe )、有名/命名管道 (named pipe) 、信号量( semophore )、消息队列( message queue ) 、信号 ( sinal ) 、共享内存( shared memory ) 、套接字( socket );今天主要讲的是命名管道,其他的大家有兴趣的可以去了解。

管道和命名管道的区别

管道是一种两个进程间进行单向通信的机制。因为管道传递数据的单向性,管道又称为半双工管道。管道的这一特点决定了器使用的局限性。管道是Linux支持的最初Unix IPC形式之一,具有以下特点: