《操作系统原理》实验报告4--实验项目:Linux多进程编程.docx

上传人:王** 文档编号:722676 上传时间:2023-12-27 格式:DOCX 页数:4 大小:31.80KB
下载 相关 举报
《操作系统原理》实验报告4--实验项目:Linux多进程编程.docx_第1页
第1页 / 共4页
《操作系统原理》实验报告4--实验项目:Linux多进程编程.docx_第2页
第2页 / 共4页
《操作系统原理》实验报告4--实验项目:Linux多进程编程.docx_第3页
第3页 / 共4页
《操作系统原理》实验报告4--实验项目:Linux多进程编程.docx_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《《操作系统原理》实验报告4--实验项目:Linux多进程编程.docx》由会员分享,可在线阅读,更多相关《《操作系统原理》实验报告4--实验项目:Linux多进程编程.docx(4页珍藏版)》请在优知文库上搜索。

1、操作系统原理实验报告实验序号:4实验项目:LinUX多进程编程学号姓名专业、班级实验地点指导教师实验时间一、实验目的及要求通过本实验的学习,掌握LinUX多进程编程的基本方法。二、实验设备(环境)及要求VMware虚拟机软件,Ubuntu系统三、实验内容与步骤1 .根据教材实践LinUX进程管理指令jonzubuntu:$ PID TTY3994 pts 528 pts jonz0ubuntu:$PS TIME CMD :60:oo bash :66:06 ps通过ps查看进程JonZUbUntu:5PS-UWarning:badpssyntax,perhapsabogus,?Seehttp:

2、/USER Jonz jonzSTAT STARTTIMECOMMANDSs Sep21rbashR+ 06:116:66ps -UPID%CPU%HEMVSZRSSTTY3994.387283644pts5286.l49481132pts使用参数进行查看2 .利用LinUX多进程编程实现以下功能:创建两个子进程;一个子进程(生产者进程)依次向缓冲区写入整数0,12.,19;另一个子进程(消费者进程)暂停3s后,从缓冲区读数,每次读一个,并将读出的数字从缓冲区删除,然后将数字显示出来;父进程等待子进程2(消费者进程)的退出信息,待收集到该信息后,父进程就返回。Stncludefftnclude

3、VUnlStd.h,MincludeVStdltb.h,“IncludeStncludeeincludenat(vo)(tntt=;Int*nCount;tntpfd;charszBuff三;tntstatus;PtLtptd;ptpe(pfd);If(fork()三三)(Cout=MaIloC(SlZeOf(tnt)*);for(t三;t;+1)(Coutt=t;SPrIntf(SZBUff,szBuff,Coutt);)wrtte(pfd,szBuff,StrIen(SZBUff);free(nCount);close(pfd);close(pfd);)else(tf(fork()=)(p

4、rtntf(n);sleep();read(pfd,szBuff,);prtntf(,szBuff);close(pfd);close(pfd);)elseptd=watt(ftstatus);t=WEXITSTATUS(status);prttf(,ptd,t);ptd=Watt(Astatus);t=WEXITSTATUS(status);prtntf(,ptd,t);)close(pfd);close(pfd);编写实验代码jonzubuntu:*/CProgram$vimexam4.cjonz0ubutu:/CProgram$gcc-oexam4exam4.cjonzubuntu:/C

5、Program$.exam4sleep(3)!childis9812,exitstatus=0”23456789IelII213141516171819UhtIdts9813,exitStdtUS=e编译程序并运行。四、分析与讨论本实验涉及到多进程编程,是需要进一步学习的部分。五、教师评语成绩签名:日期:附:第二题的源代码#include#include#include#include#include#includeintmain(void)(inti=0;int*nCount;intpfd2;charszBuff3O=0);intstatus;pid_tpid;ie(pfd);if(fbrk

6、()=O)(nCount=malloc(sizeof(int)*20);for(i=0;i20;+i)(nCounti=i;sprintf(szBuff,%s%d,szBuff,nCounti);)write(pfdll,szBuff,slrlen(szBuf11);free(nCount);close(pfd01);close(pfdll);elseif(fork()=0)printf(sleep!n);sleep(3);read(pfd0,szBuff,30);Printf(%sn,szBuff);close(pfd0);close(pfdl);1else(pid=wait(festatus);i=WExiTSTATUS(Status);printf(childis%d,exitstatus=%dn,pid,i);pid=wait(festatus);i=WExiTSTATUS(Status);printf(childis%d,exitstatus=%dn,pid,i);close(pfd0);close(pfdlj);return0;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > IT计算机 > 计算机原理

copyright@ 2008-2023 yzwku网站版权所有

经营许可证编号:宁ICP备2022001189号-2

本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!