c语言亲缘线程通过管道通信一些疑问
亲缘线程在使用管道时,发现第一次使用管道进行进行通信完全正常(./a.out 1),但当重新运行并使用新管道文件时候出现数据无法读取的问题(./a.out 2)(./a.out 3),甚至出现子线程部分语句并未执行问题,下面程序中会出现子进程perror(write)及以后语句未执行得到问题
1 #include<sys/types.h>
2 #include<sys/stat.h>
3 #include<unistd.h>
4 #include<fcntl.h>
5 #include<stdio.h>
6 #include<string.h>
7 int main(int argc ,char *argv[]){
8 umask(0);
9 mkfifo(argv[1],0777);
10 int len=0;
11 int *p=&len;
12 pid_t pid=fork();
13 perror("fork");
14 if(pid==0){
15 int fd=open(argv[1],O_WRONLY);
16 //perror("open");
17 char buff[]={'0'};
18 printf("这是子进程!\n");
19 printf("请输入要通信的字符:");
20 scanf("%s",buff);
21 *p=strlen(buff);
22 write(fd,buff,strlen(buff));
23 perror("write");
24 printf("子进程len:%d\n",*p);
25 close(fd);
26 }
27
28 else{
29 int fd=open(argv[1],O_RDONLY);
30
31 //perror("open");
32 sleep(5);
33 printf("父进程len:%d\n",*p);
34 char buff[20]={0};
35 printf("这是父进程!\n");
36 read(fd,buff,20);
37 perror("read");
38 printf("父进程读出:%s\n",buff);
39 close(fd);
40 }
41 return 0;
42 }
[root@localhost pid]# ./a.out 1
fork: Success
fork: Success
这是子进程!
请输入要通信的字符:23osd
write: Success
子进程len:5
父进程len:0
这是父进程!
read: Success
父进程读出:23osd
[root@localhost pid]# ./a.out 2
fork: Success
fork: Success
这是子进程!
请输入要通信的字符:sdgksls
父进程len:0
这是父进程!
read: Success
父进程读出:
[root@localhost pid]# ./a.out 3
fork: Success
fork: Success
这是子进程!
请输入要通信的字符:dflhlf'fd
父进程len:0
这是父进程!
read: Success
父进程读出:
[root@localhost pid]# ./a.out 1
fork: File exists
fork: File exists
这是子进程!
请输入要通信的字符:wqla
write: File exists
子进程len:4
父进程len:0
这是父进程!
read: File exists
父进程读出:w
[root@localhost pid]# ./a.out 1
fork: File exists
fork: File exists
这是子进程!
请输入要通信的字符:hdshds
write: File exists
子进程len:6
父进程len:0
这是父进程!
read: File exists
父进程读出:hdshds
[root@localhost pid]# ./a.out 1
fork: File exists
fork: File exists
这是子进程!
请输入要通信的字符:wejhee
write: File exists
子进程len:6
父进程len:0
这是父进程!
read: File exists
父进程读出:wejhee
[root@localhost pid]# ./a.out 1
fork: File exists
fork: File exists
这是子进程!
请输入要通信的字符:ahjk2';
父进程len:0
这是父进程!
read: File exists
父进程读出:
[root@localhost pid]# ./a.out 1
fork: File exists
fork: File exists
这是子进程!
请输入要通信的字符:ajgaka
write: File exists
子进程len:6
父进程len:0
这是父进程!
read: File exists
父进程读出:ajgaka
[root@localhost pid]#
c语言亲缘线程通过管道通信一些疑问的更多相关文章
- java多线程通过管道流实现不同线程之间的通信
java中的管道流(pipeStream)是一种特殊的流,用于在不同线程间直接传送数据.一个线程发送数据到输出管道,另外一个线程从输入管道中读取数据.通过使用管道,实现不同线程间的通信,而不必借助类似 ...
- java 多线程:线程通信-等待通知机制wait和notify方法;(同步代码块synchronized和while循环相互嵌套的差异);管道通信:PipedInputStream;PipedOutputStream;PipedWriter; PipedReader
1.等待通知机制: 等待通知机制的原理和厨师与服务员的关系很相似: 1,厨师做完一道菜的时间不确定,所以厨师将菜品放到"菜品传递台"上的时间不确定 2,服务员什么时候可以取到菜,必 ...
- Java多线程编程-线程之间的通信
转载自:这里 学习了基础的线程知识 看到了 线程之间的通信 线程之间有哪些通信方式呢? 1.同步 这里讲的同步是指多个线程通过synchronized关键字这种方式来实现线程间的通信. public ...
- C++和C#进程之间通过命名管道通信(上)
C++和C#进程之间通过命名管道通信(上) "命名管道"是一种简单的进程间通信(IPC)机制.命名管道可在同一台计算机的不同进程之间,或在跨越一个网络的不同计算机的不同进程之间,支 ...
- PHP多进程编程(2):管道通信
一个进程如果是个人英雄主义,那么多进程就是集体主义.(不严格区分多进程 和 多线程的差别) 你不再是一个独行侠,而是一个指挥家. 独来独往,非常自由自在,但是,很多时候,不如众人拾柴火焰高. 这就是我 ...
- Linux IPC之管道通信
2017-04-07 管道通信在linux中使用较为频繁的进程通信机制.基于unix一切皆文件的传统,管道也是一种文件.所以可以使用一般的VFS接口对管道进行读写操作,如read.write.具体管道 ...
- java多线程三之线程协作与通信实例
多线程的难点主要就是多线程通信协作这一块了,前面笔记二中提到了常见的同步方法,这里主要是进行实例学习了,今天总结了一下3个实例: 1.银行存款与提款多线程实现,使用Lock锁和条件Condition. ...
- Java并发读书笔记:如何实现线程间正确通信
目录 一.synchronized 与 volatile 二.等待/通知机制 等待 通知 面试常问的几个问题 sleep方法和wait方法的区别 关于放弃对象监视器 三.等待通知典型 生产者消费者模型 ...
- windows10使用VS(VC++)创建c++多进程命名管道通信
代码可以在 这里 下载 代码主要涉及到: 管道通信 多线程(含临界区) 多进程通信 创建的子进程独立运行 更新日志: 04-12-2020 1. 去除自定义函数返回值,改为int作为函数返回值并增加相 ...
随机推荐
- sql server 学习笔记 ( backup 备份方案 )
做个记入就好 USE [master] SELECT bs.database_name AS 'Database Name', bs.backup_start_date AS 'Backup Star ...
- InitializingBean和DisposableBean
InitializingBean 记住一点:InitializingBean接口为bean提供了初始化方法的方式,它只包括afterPropertiesSet方法,凡是继承该接口的子类,在初始化bea ...
- highly variable gene | 高变异基因的选择 | feature selection | 特征选择
在做单细胞的时候,有很多基因属于noise,就是变化没有规律,或者无显著变化的基因.在后续分析之前,我们需要把它们去掉. 以下是一种找出highly variable gene的方法: The fea ...
- 老老实实学WCF
老老实实学WCF 第三篇 在IIS中寄宿服务 通过前两篇的学习,我们了解了如何搭建一个最简单的WCF通信模型,包括定义和实现服务协定.配置服务.寄宿服务.通过添加服务引用的方式配置客户端并访问服务.我 ...
- LeetCode--004--寻找两个有序数组的中位数(java)
转自https://blog.csdn.net/chen_xinjia/article/details/69258706 其中,N1=4,N2=6,size=4+6=10. 1,现在有的是两个已经排好 ...
- 在线linux 平台
1.http://www.shiyanlou.com/[实验楼] 2.http://bellard.org/jslinux/[大牛平台]
- MySQL使用的常见问题
(一)是否启动了服务器 如果没有启动报错:ERROR 2003 (HY000): Can't connect to MySQL server on ‘localhost' (10061) 解决方法:启 ...
- 【PowerDesigner】【5】数据模型 CDM
前言:各种箭头的含义其实我还是有点混乱,所以这里只做记录 参考博客: 1,Powerdesigner数据库建模--概念模型--ER图[转] - holycrap - 博客园https://www.cn ...
- stl中常用的排序算法
#include"iostream" #include"vector" using namespace std; #include"string&qu ...
- hbase知识
HBASE是一个高可靠性.高性能.面向列.可伸缩的分布式存储系统 HBASE的目标是存储并处理大型的数据,更具体来说是仅需使用普通的硬件配置,就能够处理由成千上万的行和列所组成的大型数据. HBASE ...