有名管道(二)

 

一、从FIFO中读取数据:

约定:如果一个进程为了从FIFO中读取数据而以阻塞的方式打开FIFO,则称内核为该进程的读操作设置了阻塞标志。

  • 如果有进程为写而打开FIIF(写端存在),且当前FIFO内没有数据,则对于设置了阻塞标志的读操作来说,将一直阻塞,对于没有设置阻塞标志读操作来说返回-1,当前errno值为EAGAIN提醒以后再试。
  • 对于设置阻塞标志的读操作来说,造成阻塞的原因有两种,当前FIFO内有数据,但其他进程正在读这些数据;另外FIFO内没有数据。解阻塞的原因则是FIFO中有新的数据写入,不论写入数据量的大小,也不论读操作请求多少数据量。
  • 如果没有进程写打开FIFO,则设置了阻塞标志的读操作会阻塞。
  • 如果写端关闭,管道中有数据读取管道中的数据,如果管道没有数据读端将不会继续阻塞,此时返回0。(注意:如果FIFO有数据,则设置了阻塞标志的读操作来说不会因为FIFO的字节数小于请求读的字节数而阻塞,读操作会返回FIFO现有的数据量。)

 

二、向FIFO中写入数据

约定:如果一个进程为了向FIFO中写入数据而阻塞打开FIFO,那么称该进程内的写操作设置了阻塞标志。

1. 对于设置了阻塞标志的写操作:

  • 当写入数据量不大于PIPE_BUF时,linux将保证写入的原子性,如果此时管道空闲缓冲区不足以容纳要写入的字节数,则进入睡眠,直到缓冲区中能够写入的字节数,才开始进行一次性写操作。
  • 当要写入的数据量大于PIPE_BUF时,Linux将不再保证写入的原子性。FIFO缓冲区一有空闲,写进程就会试图向管道写入数据,写操作在写完所有请求写的数据后返回。

2. 对于没有设置阻塞标志的写操作:

  • 当要写入的数据量大于PIPE_BUF时,Linux将不再保证写入的原子性。在写满所有FIFO空闲缓冲区后,写操作返回。
  • 当要写入的数据量不大于PIPE_BUF时,linux将保证写入的原子性,如果当前FIFO空闲缓冲区能够容纳写入的字节数,写完成功返回;如果当前FIFO空闲缓冲区不能容纳请求写入的字节数,则返回EANGIN错误,提醒以后再写。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385522.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java面试2021,java数据可视化项目

AOP简介 AOP (Aspect Oriented Programing) 称为:面向切面编程,它是一种编程思想。AOP 是 OOP(面向对象编程 Object Oriented Programming)的思想延续 AOP采取横向抽取机制,取代了传统纵向继承体系重复性代码的编写方式&#xff0…

gcc的使用

一、gcc编译过程示意图 分析: hello程序是一个高级C语言程序,这种形式容易被人读懂。为了在系统上运行hello.c程序,每条C语句都必须转化为低级机器指令。然后将这些指令打包成可执行目标文件格式,并以二进…

Java面试2021,java黑马百度云

线程是否要锁住同步资源 锁住 悲观锁不锁住 乐观锁 锁住同步资源失败 线程是否要阻塞 阻塞不阻塞自旋锁,适应性自旋锁 多个线程竞争同步资源的流程细节有没有区别 不锁住资源,多个线程只有一个能修改资源成功,其它线程会重试无锁同一个线…

gdb使用

[sunbinlocalhost ~]$ gcc -Wall -g simple.c -o simple [sunbinlocalhost ~]$ ./simple Entering main ... result[1-100] 5050 result[1-10] 55 Exiting main ... [sunbinlocalhost ~]$ gdb simple 启动gdb GNU gdb (GDB) Red Hat Enterprise Linux 7.6.1-110.el7 Copyrigh…

oppoJava面试题,java声明全局变量的关键字

蚂蚁一面 ⼀⾯就做了⼀道算法题,要求两⼩时内完成,给了⻓度为N的有重复元素的数组,要求输出第10⼤的数。典型的TopK问题,快排算法搞定。算法题要注意的是合法性校验、边界条件以及异常的处理。另外,如果要写测试⽤例&…

System V 消息队列

一、System V 消息队列 有一个队列,队列存放各种消息。每个进程可以把数据封存在消息中,再放入队列。每个进程都可以拿到消息队列,再从中取出/放入消息。 消息队列也有管道一样的不足,就是每个消息的最大长度是有上限的&#xf…

oppoJava面试题,java连接数据库详细步骤

美团一面(50分钟左右) 进程和线程死锁的必要条件网络,七层协议TCP和UDP的区别hashmap 详细讲一下hashmap底层是如何解决hash冲突的hashmap和linkedhashmap数据库的索引,为什么推荐自增id,有什么优点MySQL的引擎&#…

基本TCP套接字编程

1. socket函数原型&#xff1a; #include <sys/socket.h> int socket(int domain, int type, int protocol);2. bind函数原型&#xff1a; #include <sys/socket.h> int bind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen);参数&#xff1a; ​ st…

oppoJava面试题,腾讯社招三面多久联系

梳理知识点&#xff0c;是快速提升技术的关键 前面讲过&#xff0c;快速提升自己的技术硬实力其实是有方法的。大致就是梳理知识点夯实基础进阶深入学习实战&#xff0c;下面我会一点点跟大家剖析&#xff0c;本文干货满满&#xff0c;大家仔细阅读。 ①梳理知识必备&#xff1…

oppoJava面试!传智播客java基础案例教程

零基础如何学习Java&#xff1f; 首先&#xff0c;你要明白一点&#xff0c;Java入门不难&#xff01; 无论你是从事哪个行业&#xff0c;兴趣一定是最好的老师&#xff0c;也是你学习的动力。 学习方式1&#xff1a;自学 自学模式其实我个人不建议绝大部分的人选择&#x…

Redis高级项目实战!北京java编程入门培训

Dubbo面试专题 JVM面试专题 Java并发面试专题 Kafka面试专题 MongDB面试专题 MyBatis面试专题 MySQL面试专题 Netty面试专题 RabbitMQ面试专题 Redis面试专题 Spring Cloud面试专题 SpringBoot面试专题 zookeeper面试专题 最后 给大家送一个小福利 资料都是免费分享的&#xf…

poll函数

#include <poll.h> int poll(struct pollfd *fds, nfds_t nfds, int timeout);参数&#xff1a; fds&#xff1a;监听的文件描述符【数组】 struct pllfd {int fd; 待监听的文件描述符short events; 待监听的文件描述符对应的监听事件short revents; 传入时&…

Redis高级项目实战,java配置jdk环境时

Spring Security观后感——手绘思维脑(供参考) Spring Security手绘思维脑图 手绘的思维导图&#xff0c;是我自己根据自身的情况读完这套阿里出品的Spring Security王者晋级文档之后所绘的&#xff0c;相当于是一个知识的总结与梳理&#xff0c;我将其分为***“核心组件”与“…

select函数(一)

int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout); 参数&#xff1a; nfds&#xff1a;监控的文件描述符集里最大文件描述符加1&#xff0c;因为此参数会告诉内核检测前多少个文件文件描述符readfs&#xff1a;监控有读…

Redis高级项目实战,阿里P7级别面试经验总结

第一次压测 惨不忍睹&#xff0c;平均响应时间150ms&#xff0c;而且在这次压测过程中还发现其它的问题&#xff0c;后台报错&#xff0c;经查是OpenSearch每秒查询次数限制 优化代码与配置 1、修改OpenSearch配置&#xff0c;并且将压测环境中的OpenSearch连接地址改为内网地…

Makefile用法链接

Makefile的编写及四个特殊符号的意义、$、$^、$ <font face"字体" size"字号" color"颜色">这里是需要突出显示的内容</font> <font color#0099ff size12 face"黑体">黑体</font>

Redis高频面试笔记:java版本号比较算法

1.三重心智模型 先给大家科普一个概念&#xff0c;“三重心智模型”。 认知科学家斯坦诺维奇&#xff0c;将人的心智模式&#xff0c;分成了三个部分。 第一层是自主心智&#xff0c;自主心智是我们通过进化与内隐学习获得。比如&#xff0c;我们看到蛇就会害怕&#xff0c;情…

Redis高频面试笔记:mysql8.0新特性

一、服务发布简介 分布式系统架构下&#xff0c;服务发布是一件很麻烦的事情&#xff0c;特别是在构建自动发布流程和灰度测试的策略两个核心方面。通常情况下如果不涉及数据层面的灰度流程&#xff0c;服务可以灰度上线&#xff0c;或者滚动上线&#xff0c;这两种方式很常用…

Makefile (二)

一、line1的源码 line1.h #ifndef _LINE_1_H #define _LINE_1_H void line1_print(const char *strMsg); #endifline1.cpp #include "line1.h" #include <stdio.h> void line1_print(const char *strMsg) {printf("This is line1 print %s.\r\n",st…

RocketMQ避坑指南:springcloud教程权威指南

1. Java 堆空间 **发生频率&#xff1a;**5颗星 造成原因 无法在 Java 堆中分配对象 吞吐量增加 应用程序无意中保存了对象引用&#xff0c;对象无法被 GC 回收 应用程序过度使用 finalizer。finalizer 对象不能被 GC 立刻回收。finalizer 由结束队列服务的守护线程调用&a…