APUE读书笔记-第十五章-进程间通信
管道
创建管道(pipe函数)
#include <unistd.h>
int pipe(int fd[2);
fd[0]为读打开,fd[1]为写打开
局限性
(1)管道是半双工的,数据只能向一个方向流动
(2)只能用于具有亲缘关系的进程之间
(3)没有名字
(4)管道的缓冲区是有限的,由常量PIPE_BUF定义
(5)管道所传送的是无格式字节流,这就要求管道的读出方和写入方必须事先约定好数据的格式
管道实现进程同步的五个函数
TELL_WAIT、TELL_PARENT、TELL_CHILD、WAIT_PARENT、WAIT_CHILD
#include "apue.h"static int pfd1[2], pfd2[2];void
TELL_WAIT(void)
{if (pipe(pfd1) < 0 || pipe(pfd2) < 0)err_sys("pipe error");
}void
TELL_PARENT(pid_t pid)
{if (write(pfd2[1], "c", 1) != 1)err_sys("write error");
}void
WAIT_PARENT(void)
{char c;if (read(pfd1[0], &c, 1) != 1)err_sys("read error");if (c != 'p')err_quit("WAIT_PARENT: incorrect data");
}void
TELL_CHILD(pid_t pid)
{if (write(pfd1[1], "p", 1) != 1)err_sys("write error");
}void
WAIT_CHILD(void)
{char c;if (read(pfd2[0], &c, 1) != 1)err_sys("read error");if (c != 'c')err_quit("WAIT_CHILD: incorrect data");
}
函数popen和pclose
创建一个管道,fork一个子进程,关闭未使用的管道端,执行一个shell命令,然后等待命令终止
#include <stdio.h>
FILE *popen(const char *command, const char *type);
int pclose(FILE *fp);
函数popen先执行fork,然后调用exec执行cmdstring,并且返回一个标准I/O文件指针。
如果type是“r”,则文件指针连接到cmdstring的标准输出
如果type是“w”,则文件指针连接到cmdstring的标准输入
协同进程
一个过滤程序既产生某个过滤程序的输入,又读取该过滤程序的输出,该过滤进程就变成了协同进程
FIFO
创建FIFO
#include <sys/stat.h>
int mkfifo(const char *path, mode_t mode);
int mkfifoat(int fd, const char *path, mode_t mode);
命名管道需要用open打开,在open时,用O_NONBLOCK 标志表示非阻塞
两种用途
(1)shell命令使用FIFO将数据从一条管道传送到另一条时,无需创建中间临时文件
(2)客户进程-服务器进程应用程序中,FIFO用于汇聚点,在客户进程和服务器进程二者之间传递数据
命名管道以FIFO的文件形式存在于文件系统中
不相关的进程也能够彼此通过FIFO交换数据
FIFO严格遵循先进先出(first in first out),对管道及FIFO的读总是从开始处返回数据,对它们的写则把数据添加到末尾。它们不支持诸如lseek()等文件定位操作
APUE读书笔记-第十五章-进程间通信相关推荐
- 《Windows核心编程》读书笔记二十五章 未处理异常,向量化异常处理与C++异常
第二十五章 未处理异常,向量化异常处理与C++异常 本章内容 25.1 UnhandledExceptionFilter函数详解 25.2 即时调试 25.3 电子表格示例程序 25.4 向量化异常 ...
- apue读书笔记-第十二章
1 可重入,线程安全,异步信号安全之间的区别? 可重入:可以重复进入,不会引起问题(这个概念最宽) 线程安全:被多个线程使用时,不会出问题,也就是可以被多个进程重入(新函数和被终端和被中断的函数不在同 ...
- [hadoop读书笔记] 第十五章 sqoop1.4.6小实验 - 将mysq数据导入hive
安装hive 1.下载hive-2.1.1(搭配hadoop版本为2.7.3) 2.解压到文件夹下 /wdcloud/app/hive-2.1.1 3.配置环境变量 4.在mysql上创建元数据库hi ...
- 大数据之路、阿里巴巴大数据实践读书笔记 --- 第十五章、数据质量
随着IT向DT时代的转变,数据的重要性不言而喻,数据的应用也日趋繁茂,数据正扮演着极其重要的角色.而对于被日益重视的数据,如何保障其质量是一个关注的话题: 数据质量是数据分析结论有效性和准确性的基础, ...
- 《深入浅出DPDK》读书笔记(十五):DPDK应用篇(Open vSwitch(OVS)中的DPDK性能加速)
Table of Contents Open vSwitch(OVS)中的DPDK性能加速 174.虚拟交换机简介 175.OVS简介 176.DPDK加速的OVS 177.OVS的数据通路 178. ...
- 强化学习(RLAI)读书笔记第十六章Applications and Case Studies(不含alphago)
强化学习(RLAI)读书笔记第十六章Applications and Case Studies(不含alphago) 16.1 TD-Gammon 16.2 Samuel's Checkers Pla ...
- 强化学习(RLAI)读书笔记第十六章Applications and Case Studies(alphago)
强化学习(RLAI)读书笔记第十六章Applications and Case Studies(alphago) 16.6 Mastering the Game of Go 16.6.1 AlphaG ...
- 【Python自然语言处理】读书笔记:第五章:分类和标注词汇
jupyter 版请见我的github:https://github.com/JackKuo666/Python_nlp_notes [Python自然语言处理]读书笔记:第五章:分类和标注词汇 本章 ...
- R语言实战笔记--第十五章 处理缺失数据
R语言实战笔记–第十五章 处理缺失数据 标签(空格分隔): R语言 处理缺失数据 VIM mice 缺失值(NA),是导致我们计算错误的一大来源,处理缺失数据在实际的应用中有着较为重要的作用. 基本方 ...
最新文章
- 关于redis的几件小事(一)redis的使用目的与问题
- 粒子群算法参数w的改进
- Java黑皮书课后题第2章:2.10(科学:计算能量)编写程序,计算将水从初始温度加热到最终温度所需的能量。程序应该提示用户输入水的重量(kg),以及水的初始温度、最终温度
- 八千字硬核长文梳理Linux内核概念及学习路线
- 微信php实例代码_php微信公众平台示例代码分析(二)
- 学python心得体会800字-Python初学心得体会
- PHP_零基础学php_3PHP函数、传参函数、默认参数、函数返回值
- 计算数据个数mysql thinkphp_ThinkPHP5 (mySQL) 统计各个时间段内的订单量
- 个人作业7 第一阶段SCRUM冲刺(九)
- 2022机修钳工(中级)特种作业证考试题库模拟考试平台操作
- MATLAB 整数小数负数十进制转换为十六进制
- MOS管的行业应用领域-KIA MOS管
- Android仿微信朋友圈7实现点赞功能
- python 爬取《延禧攻略》所有的演员参演的电视剧
- 华为通用软件开发面试(一二+主管面)
- 步进电机基础知识(转载)
- 文件服务器打开八下地理导学案,七年级地理下册 7.4 俄罗斯导学案(新版)新人教版...
- [IMX6Q]u-boot启动kernel流程
- 荣耀手表2鸿蒙推送时间,鸿蒙OS正式版推送时间确定!荣耀机型也有份,六月初全面升级...
- 2005年度《超级女声》冠军李宇春登上美国《时代周刊》而后的评论?
热门文章
- MyBatis代码生成器Gradle插件分享
- 诺奖得主本庶佑:真正一流的工作往往没有在顶级刊物上发表!
- android studio 皮肤,Android Studio 自定义皮肤主题和背景
- vue css变量实现多主题皮肤切换
- 惠普HP dc7900的BIOS如何开启虚拟化VT设置
- growup怎么读_grow up是什么意思_grow up怎么读_grow up翻译_用法_发音_词组_同反义词_向上生长-新东方在线英语词典...
- SHELL命令里面的EQ、NE、GT、LT、GE、LE分别是什么意思
- 命令行(cmd.exe)中操作注册表
- redis 生产环境 谨慎执行的命令
- 2.【OS】vscode下载很慢的问题