一进程通信概述.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一进程通信概述

一:进程通信概述 什么是进程间通信? 什么是线程间通信? 进程通信:在用户空间实现进程通信是不可能的,通过Linux内核通信 线程间通信:可以在用户空间就可以实现,可以通过全局变量通信。 有哪几种通信方式? 管道通信:无名管道、有名管道(文件系统中有名) 信号通信:信号(通知)通信包括:信号的发送、信号的接收和信号的处理。 IPC(Inter-Process Communication)通信:共享内存、消息队列和信号灯。 以上是单机模式下的进程通信(只有一个Linux内核) Socket通信:存在于一个网络中两个进程之间的通信(两个Linux内核)。 进程通信课程的学习思路:每一种通信方式都是基于文件IO的思想。 open:功能:创建或打开进程通信对象。函数形式不一样,有的是有多个函数完成。 write: 功能:向进程通信对象中写入内容。函数形式可能不一样。 read: 功能:从进程通信对象中读取内容。函数形式可能不一样。 close: 功能:关闭或删除进程通信对象。形式可能不一样。 二:无名管道 通信原理: 内核 管道 进程1 进程2 管道文件是一个特殊的文件,是由队列来实现的。 在文件IO中创建一个文件或打开一个文件是由open函数来实现的,它不能创建管道文件。只能用pipe函数来创建管道。 函数形式:int pipe(int fd[2]) 功能:创建管道,为系统调用:unistd.h 参数:就是得到的文件描述符。可见有两个文件描述符:fd[0]和fd[1],管道有一个读端fd[0]用来读和一个写端fd[1]用来写,这个规定不能变。 返回值:成功是0,出错是-1; 例1:pipe函数使用。 注意: 管道中的东西,读完了就删除了;队列 如果管道中没有东西可读,则会读阻塞。 例2:验证读阻塞。 例3:验证写阻塞:可以计算出内核开辟的管道有多大。5456 5457 例4:实现进程通信。 无名管道的缺点:只能实现父子进程(有亲缘关系进程)之间的通信。 正由于这无名管道的缺点,对无名管道进行改进:有名管道。 所谓的有名,即文件系统中存在这个一样文件节点,每一个文件节点都有一个inode号 而且这是一个特殊的文件类型:p管道类型。 创建这个文件节点,不可以通过open 函数,open 函数只能创建普通文件,不能创建特殊文件(管道-mkdifo,套接字-socket,字符设备文件-mknod,块设备文件-mknod,符号链接文件-ln –s,目录文件mkdir) 管道文件只有inode号,不占磁盘块空间,和套接字、字符设备文件、块设备文件一样。普通文件和符号链接文件及目录文件,不仅有inode号,还占磁盘块空间。 3. mkfifo 用来创建管道文件的节点,没有在内核中创建管道。 只有通过open 函数打开这个文件时才会在内核空间创建管道。 mkfifo 函数形式:int mkfifo(const char *filename,mode_t mode); 功能:创建管道文件 参数:管道文件文件名,权限,创建的文件权限仍然和umask有关系。 返回值:创建成功返回0,创建失败返回-1。 例1:mkfifo的用法。 例子:通过管道实现无亲缘关系进程间通信。 三:信号 信号通信,其实就是内核向用户空间进程发送信号,只有内核才能发信号,用户空间进程不能发送信号。 内核可以发送多少种信号呢? kill -l 命令:kill -9 pid 信号通信的框架 信号的发送(发送信号进程):kill raise alarm 信号的接收(接收信号进程) : pause() sleep while(1) 信号的处理(接收信号进程)?: signal 信号的发送(发送信号进程) kill?: 所需头文件#include signal.h #include sys/types.h函数原型int kill(pid_t pid, int sig);函数传入值pid:正数:要接收信号的进程的进程号0:信号被发送到所有和pid进程在同一个进程组的进程-1:信号发给所有的进程表中的进程(除了进程号最大的进程外)sig:信号函数返回值成功:0 出错:-1 kill命令的程序实现实例。 raise: 发信号给自己 == kill(getpid(), sig) 所需头文件#include signal.h #include sys/types.h函数原型int raise(int si

文档评论(0)

sunhao111 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档