Windows系统编程之进程间通信作者:北极星2003来源:看雪论坛(www.pediy.com)Windows 的IPC(进程间通信)机制主要是异步管道和命名管道.(至于其他的IPC方式,例如内存映射.邮槽等这里就不介绍了)管道(pipe)是用于进程间通信的共享内存区域.创建管道的进程称为管道服务器,而连接到这个管道的进程称为管道客户端.一个进程向管道写入信息,而另外一个进程从管道读取信息.异步管道是基于字符和半双工的(即单向),一般用于程序输入输出的重定向:命名管道则强大地多,它们是面向消息…
管道是Linux中很重要的一种通信方式,是把一个程序的输出直接连接到另一个程序的输入,常说的管道多是指无名管道,无名管道只能用于具有亲缘关系的进程之间,这是它与有名管道的最大区别.有名管道叫named pipe或者FIFO(先进先出). 管道具有以下特点: 1.管道是半双工的,数据只能向一个方向流动:需要双方通信时,需要建立起两个管道: 2.只能用于父子进程或者兄弟进程之间(具有亲缘关系的进程): 3.单独构成一种独立的文件系统:管道对于管道两端的进程而言,就是一个文件,但它不是普通的文件,它不…
目录 1. 进程 1.1 概念 1.2 查看进程 1.3 启动新进程 1.3.1 system() 函数 1.3.2 fork() 函数 1.3.2 exce 系列函数 1.3.2.1 exce 系列函数说明 1.3 终止进程 1.4 等待进程 1.4.1 wait() 函数 1.4.2 waitpid() 函数 2. 管道 2.1 概念 2.2 匿名管道 2.2.1 匿名管道特征 2.2.2 pipe() 函数 2.3 命名管道 2.3.1 命名管道特征 2.3.2 创建命名管道命令 2.3.…
进程间通信-mmap #include <sys/mman.h> void *mmap(void *addr, size_t length, int prot, int flags, int fd, off_t offset); int munmap(void *addr, size_t length); mmap本质是把内存与硬盘上的文件同步.某块内存中的内容会同步到硬盘文件上,即把文件映射到内存.故通过对同一文件的读写达到进程间的通信. 參数解释: addr:指定对哪儿块内存实行映射. N…
进程间通信-fifo 进程间通信的还有一种方式是fifo. fifo是还有一种管道:有名管道.从名字能够看出.它也是队列. 使用fifo通信前,得先创建fifo $ mkfifo myfifo 随后仅仅需对myfifo像文件一样使用即可. fifo_w.c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sys/types.h> #include <sys/sta…
管道的概述 管道也叫无名管道,它是是 UNIX 系统 IPC(进程间通信) 的最古老形式,全部的 UNIX 系统都支持这样的通信机制. 无名管道有例如以下特点: 1.半双工,数据在同一时刻仅仅能在一个方向上流动. 2.数据仅仅能从管道的一端写入,从还有一端读出. 3.写入管道中的数据遵循先入先出的规则. 4.管道所传送的数据是无格式的,这要求管道的读出方与写入方必须事先约定好数据的格式,如多少字节算一个消息等. 5.管道不是普通的文件,不属于某个文件系统,其仅仅存在于内存中. 6.管道在内存中相…
IPC方法 Linux环境下,进程地址空间相互独立,每个进程各自有不同的用户地址空间.任何一个进程的全局变量在另一个进程中都看不到,所以进程和进程之间不能相互访问, 要交换数据必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷到内核缓冲区,进程2再从内核缓冲区把数据读走,内核提供的这种机制称为进程间通信(IPC,InterProcess Communication). 在进程间完成数据传递需要借助操作系统提供特殊的方法,如:文件(文件打开之后产生一个文件结构体在内核中,不同进程打开同…
Linux 系统编程 学习:02-进程间通信1:Unix IPC(1)管道 背景 上一讲我们介绍了创建子进程的方式.我们都知道,创建子进程是为了与父进程协作(或者是为了执行新的程序,参考 Linux exec族函数解析 ) 我们也知道,进程之间的资源在默认情况下是无法共享的,所以我们需要借助系统提供的 进程间通信(IPC, InterProcess Communication) 有关的接口. 进程间通信 由于进程间的地址空间相对独立.进程与进程间不能像线程间通过全局变量通信,所以进程之间要交换数…
基本操作命令: ps -ajx/-aux/-ef 查看进程间状态/的相互关系 top 动态显示系统中的进程 nice 按照指定的优先级运行 /renice 改变正在运行的进程的优先级 kill -9杀死进程 jobs 查看后台进程数 进程的结构.类型.状态.模式 0.Linux中进程包括三段: (1)数据段.存放的是全局变量,常量以及动态内存的数据空间. (2)正文段.存放的是程序中的代码. (3)堆栈段.存放的是函数的返回地址,函数的参数以及局部变量. 进程类型:交互进程,既可以在前台运行,也…
今天继续研究管道的内容,这次主要是研究一下命名管道,以及与之前学过的匿名管道的区别,话不多说,进入正题: 所以说,我们要知道命名管道的作用,可以进行毫无关系的两个进程间进行通讯,这是匿名管道所无法实现的. 下面来用命令创建一下: 用程序来创建: 另外管道文件是一种特珠类型的文件,所以不能用vim去像文本文件去编辑 也可以能过man帮助来查看到: 下面用一个实际的例子来说明下: 编译运行: 可以看到,此时运行已经被阻塞了,这时,我们来写一个往有名管道中写数据的程序,看看是否能解除阻塞? 这时,两个…