Linux编程练习 --进程间通信2--两个管道实现双向通信

利用两个管道进行进程间双向通信在第一篇练习已经大致作出说明,下面将进行一个更为综合的练习

首先看题目:

设有二元函数f(x,y) = f(x) + f(y)
其中: f(x) = f(x-1) * x (x >1)
f(x)=1 (x=1)
f(y) = f(y-1) + f(y-2) (y> 2)
f(y)=1 (y=1,2)
请编程建立3 个并发协作进程,它们分别完成f(x,y)、f(x)、f(y)

实现的方法很多,这里只用管道实现,大致流程如下:

1.在父进程代码中初始化四个管道,两个用于父-子进程1,另外两个父-子进程2;

2.父进程创建2个子进程,子进程1计算函数f(x),子进程2计算函数f(y);

3.父进程向子进程1、2发送数据;

4.子进程1、2均在管道里读出数据,并进行计算;

5.计算完毕后,子进程1、2向父进程发送结果;

6。父进程接受数据,打印出来

 

下面是实现过程:

[cpp] view plaincopy
  1. /*pipe3.c*/  
  2. #include <unistd.h>  
  3. #include <sys/stat.h>  
  4. #include <sys/types.h>  
  5. #include <stdio.h>  
  6. #include <fcntl.h>  
  7. #define MAXLINE 1024  
  8. #define READ    0  
  9. #define WRITE   1  
  10. /*函数x*/  
  11. int functionx(int nx);  
  12. /*函数y*/  
  13. int functiony(int ny);  
  14. main(void)  
  15. {  
  16.     pid_t pid_x,pid_y;  
  17.     int fdx1[2],fdy1[2],fdx2[2],fdy2[2];  
  18.     /*初始化管道*/  
  19.     pipe(fdx1);  
  20.     pipe(fdy1);  
  21.     pipe(fdx2);  
  22.     pipe(fdy2);  
  23.     /*创建子进程1*/  
  24.     pid_x = fork();  
  25.     if(pid_x < 0)  
  26.     {  
  27.         printf("Create process error!/n");  
  28.         exit(0);  
  29.     }  
  30.     if(pid_x == 0)  
  31.     {  
  32.         int numx,funx;  
  33.         printf("childx process ID:%d/n",getpid());  
  34.         close(fdx1[WRITE]);  
  35.         close(fdx2[READ]);  
  36.         /*从管道读出x*/  
  37.         read(fdx1[READ],&numx,sizeof(int));  
  38.         /*函数计算*/  
  39.         funx = functionx(numx);  
  40.         printf("childx  x=%d/n",funx);  
  41.         /*向管道发送*/  
  42.         write(fdx2[WRITE],&funx,sizeof(int));  
  43.         close(fdx1[READ]);  
  44.         close(fdx2[WRITE]);  
  45.     }  
  46.     if(pid_x > 0)  
  47.     {  
  48.         /*创建子进程2*/  
  49.         pid_y =fork();  
  50.         if(pid_y < 0)  
  51.         {  
  52.             printf("Create process error!/n");  
  53.             exit(0);  
  54.         }  
  55.         if(pid_y == 0)  
  56.         {  
  57.             int numy,funy;  
  58.             printf("childy process ID:%d/n",getpid());  
  59.             close(fdy1[WRITE]);  
  60.             close(fdy2[READ]);  
  61.             /*从管道读出x*/  
  62.             read(fdy1[READ],&numy,sizeof(int));  
  63.             /*函数计算*/  
  64.             funy = functiony(numy);  
  65.             printf("childy  y=%d/n",funy);  
  66.             /*向管道发送*/  
  67.             write(fdy2[WRITE],&funy,sizeof(int));  
  68.         }  
  69.         if(pid_y > 0)  
  70.         {     
  71.             int x,y,funxy;  
  72.             int fx,fy;  
  73.             sleep(1);  
  74.             printf("parentxy process ID:%d/n%",getpid());  
  75.             /*参数输入*/  
  76.             printf("enter x,y/n");  
  77.             scanf("%d,%d",&x,&y);  
  78.             close(fdx2[WRITE]);  
  79.             close(fdx1[READ]);  
  80.             close(fdy2[WRITE]);  
  81.             close(fdy1[READ]);  
  82.             /*管道发送*/  
  83.             write(fdx1[WRITE],&x,sizeof(int));  
  84.             write(fdy1[WRITE],&y,sizeof(int));  
  85.             /*等待子进程计算*/  
  86.             sleep(1);  
  87.             /*管道读入*/  
  88.             read(fdx2[READ],&fx,sizeof(int));  
  89.             read(fdy2[READ],&fy,sizeof(int));  
  90.             funxy = fx+fy;  
  91.             printf("f(x) = %d/nf(y) = %d/nfun(x,y) = %d",fx,fy,funxy);  
  92.             waitpid(pid_x,NULL,0);  
  93.             waitpid(pid_y,NULL,0);  
  94.         }  
  95.     }     
  96. }  
  97. int functionx(int nx)  
  98. {  
  99.     int sum = 1;  
  100.     int i = 1;  
  101.     if(nx < 0)  
  102.     {  
  103.         printf("errorx!/n");  
  104.         exit(0);  
  105.     }  
  106.     while(i <= nx)  
  107.     {  
  108.         sum *=i++;  
  109.     }  
  110.     return sum;  
  111. }  
  112. int functiony(int ny)  
  113. {  
  114.     int f1=1,f2=1,f3;  
  115.     int i =3;  
  116.     if(ny <= 2)  
  117.         return f1;  
  118.     while(i <= ny)  
  119.     {  
  120.         f3 = f1+f2;  
  121.         f1 = f2;  
  122.         f2 = f3;  
  123.         i++;  
  124.     }  
  125.     return f3;  
  126. }  

 

编译:

$ gcc pipe3.c -o pipe3

运行:

$ ./pipe

 

我们输入测试数据x=3,y=4

输出为f(x)=6,f(y)=3,f(x,y)=9

成功

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

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

相关文章

Windows集群网络配置最佳做法

要开始做集群了&#xff0c;找点资料来看看&#xff1a;阅读提示&#xff1a;本文为 Microsoft Windows 2000 或 Windows Server 2003 服务器群集的网络基础结构提供了服务器群集要求和最佳做法。若要群集可以正常运行&#xff0c;必须满足这些要求。最佳做法是从部署反馈和现场…

JOJ的2042面试题目的数学推导过程

JOJ的2042题目是一个程序理解题目&#xff0c;这个题目非常有意思&#xff0c;给出了下面一段C源代码&#xff0c;要求计算出最后的输出结果&#xff0c;源代码如下&#xff1a; #include<cstdio> int main(void) { int x 987654321, c 0, d 1, e 6; while…

linux mysql密码转义_linux忘记mysql密码处理方法

linux忘记mysql密码处理方法:# /etc/init.d/mysql stop# mysqld_safe --usermysql --skip-grant-tables --skip-networking &# mysql -u root mysqlmysql> update user set passwordpassword(newpassword) where userroot;mysql> flush privileges;mysql> quit# /…

不同职业的面试着装技巧。

美女姜培琳&#xff1a;传授独家心经 不同职业的面试着装技巧。 一般来说&#xff0c;职场中精英女性的装扮&#xff0c;首要应讲求端庄、稳重。人们对服饰过于花哨怪异者的工作能力、工作作风、敬业精神、生活态度等&#xff0c;都会持怀疑的态度。 其实&#x…

ARMV4,ARMV4T,ARMV4I的意义

ARMV4,ARMV4T,ARMV4I 以上表示的是指令的版本 也就是三种指令集&#xff1a; ARMv4 -> 它只支持 32 位 ARMv4 指令 ARMv4T ->“T”代表 Thumb(16 位指令模式) ARMv4I ->“I”代表交互作用 (Interworking)。它允许 32 位指令和 16 位指令共存 一些经常出现的CPU支持的指…

【转】C++中的字符串(String)和数值转换

『写在前边』 因为写PAT总是遇到字符串&#xff08;主要是String&#xff09;和数值之间的转化&#xff0c;所以整理一下以便好复习。 『String类型的字符串』 这里数值和字符串相互转换的例子&#xff0c;使用的是stringstream函数&#xff0c;在c11当中有定义好的现成的函数…

好开心

好开心&#xff01;收到我们家lily的礼物&#xff01; 前天&#xff0c;lily传给我一个flash相册&#xff0c;他将我们认识以来的合照做成了flash&#xff0c;配上了音乐。看了好感动&#xff0c;好开心&#xff01; 其实照片倒不是很多&#xff0c;也就7到8张吧&#xff0c;但…

java 实现真正的随机数_关于java:SecureRandom的Android实现是否产生真正的随机数?...

我已经阅读过&#xff0c;一般来说&#xff0c;SecureRandom的一些实现可能会产生真正的随机数。特别是&#xff0c;Android文档说instances of this class will generate an initial seed using an internal entropy source, such as /dev/urandom号但这是否意味着它将产生真正…

etherpeek nx在网络维护中的应用

摘要&#xff1a;该文分析了etherpeek nx的工作原理&#xff0c;主要利用etherpeek nx的数据包截取和分析功能来对netrobocop&#xff08;网络执法官&#xff09;数据包的分析&#xff0c;了解局域网和netrobocop的基本原理&#xff0c;从而更好地维护网络的安全和畅通。 关键…

【转】Windows编程之hdc和hwnd的区别

在windows编程中类型名前面加H的基本是句柄常用句柄 : HBITMAP 保存位图信息的内存域的句柄 HBRUSH 画刷句柄 HCTR 子窗口控件句柄 HCURSOR 鼠标光标句柄 HDC 设备描述表句柄 HDLG 对话框句柄 HFONT 字体句柄 HICON 图标句柄 HINSTANCE 应用程序实例句柄 HMENU 菜单句柄 HMODUL…

java在dos中如何测试_[求助]怎么在java中模拟dos命令行

[CODE]/** Test.java** Created on 2006年12月21日, 下午3:53** To change this template, choose Tools | Template Manager* and open the template in the editor.*/package testCMD;/**** author lbf*/import java.io.*;import java.awt.*;import java.awt.event.*;import …

谈谈基于SQL Server 的Exception Handlingp[下篇]

六、SqlException 在上面一节中&#xff0c;我给出了一个完整的例子说明了&#xff1a;如何在将message定义在sys.messages中保证message的一致性和可维护性&#xff1b;如何在Stored procedure中使用RAISERROR将一个可预知的Error抛出&#xff1b;如何在Stored procedure中使用…

char * 转LPCTSTR若干方法

如何将char* 转换为LPCTSTR&#xff1f;&#xff1f; rainForestBache (百奇) 2004-10-19 20:17:48 在 VC/MFC / 基础类 提问 请多多指教 问题点数&#xff1a;20、回复次数&#xff1a;10 1楼 stephen_young () 回复于 2004-10-19 20:33:45 得分 5 实际上将char*转…

【转】修改static控件背景颜色和文字颜色

当 static 控件或具有 ES_READONLY 风格的 edit 控件被绘制时&#xff0c;会向父窗口发送 WM_CTLCOLORSTATIC 消息。如果我们在窗口过程中处理该消息&#xff0c;就必须返回一个画刷句柄&#xff0c;Windows 会使用该画刷来绘制控件背景&#xff08;子窗口背景&#xff09;。 也…

用C#中的string.Replace有错误,无法替换。

我用的是.net 1.1&#xff0c;在编程要将[Title]替换为“这是标题”&#xff0c;用string.Replace替换总是不对&#xff1a;temp.Replace("[Title]","这是标题");temp输出后显示没有被替换。用较短的实际字符串是可以被替换的&#xff0c;所以我不怀疑我的…

java中随机数彩票练习_基于javascript实现彩票随机数生成(简单版)

本文实例讲解了JavaScript 实现彩票中随机数组的获取详细代码&#xff0c;分享给大家供大家参考&#xff0c;具体内容如下效果图&#xff1a;具体代码&#xff1a;Math.random方法彩票随机数的生成开始获取随机数组//获取节点var btnGo document.getElementById("btnGo&q…

C/C++中near和far的区别

在80286以前的微处理器&#xff08;CPU&#xff09;组成的确16位机上&#xff0c;Windows操作系统&#xff08;包括DOS&#xff09;对于内存是分段使用的&#xff08;分段内存模式&#xff0c;Segment Memory Mode&#xff09;。运行在这些16位CPU微机上的Windows&#xff…

【转】Windows编程之滚动条—滚动条消息

在用鼠标单击滚动条或者拖动卷动方块时&#xff0c;Windows给窗口消息处理程序发送WM_VSCROLL&#xff08;供上下移动&#xff09;和WM_HSCROLL&#xff08;供左右移动&#xff09;消息。在滚动条上的每个鼠标动作都至少产生两个消息&#xff0c;一条在按下鼠标按钮时产生&…

创建IE各版本专属CSS

IE下专属CSS&#xff1a; <![if !IE]><link rel"stylesheet" type"text/css" href"NOT-IE.css" /><![endif]>IE 6 ONLY: <!--[if IE 6]><link rel"stylesheet" type"text/css" href"IE-6-S…

juc是什么java_JUC简介

JUC是什么JUC是 在Java 5.0添加的 java.util.concurrent包的简称&#xff0c;目的就是为了更好的支持高并发任务&#xff0c;让开发者利用这个包进行的多线程编程时可以有效的减少竞争条件和死锁线程。JUC的结构1&#xff0c;tools(工具类)&#xff1a;又叫信号量三组工具类&am…