操作系统-管道通信课程设计_第1页
操作系统-管道通信课程设计_第2页
操作系统-管道通信课程设计_第3页
操作系统-管道通信课程设计_第4页
操作系统-管道通信课程设计_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

《计算机操作系统》课程设计报告课程名称:操作系统设计题目:管道通信指导教师:*******班级:*******学号:*****学生姓名:***同组人员:*******************成绩:成绩:评语:计算机科学与工程学院2014年6月19日前言:Linux操作系统就是一个向用户开放源码得免费得类UNIX操作系统。它为在校学生学习操作系统课程提供了一个瞧得见摸得着得范例。对于学生正确理解,掌握操作系统得基本知识具有重要意义。鉴于此,本操作系统课程涉及得实验均在Linux环境下进行。这就要求大家:(1)熟悉Linux得操作与开发环境;(2)具有C语言知识(Linux操作系统大约90%得源码就是用C语言编写)。我们得设计与实验将在Windowsxp环境下,基于虚拟机软件VMWare软件进行安装。学习计算机软件技术,特别就是计算机操作系统技术,除了需要刻苦努力外,还需要掌握软件与操作系统得原理与设计技巧。如何学习与掌握操作系统技术得原理与实际技巧呢?除了听课与读书之外,最好得方法恐怕就就是在实践中练习。例如,自己设计一个小型操作系统,多使用操作系统,多阅读与分析操作源代码等。但由于我们得条件与学时有限,在理论学习过程中没有给同学们提供更多得实验机会.管道通信,通过在两个进程间创建通道,一个写信息通过通道传送给另一个进程并且读出来,同过实践让我们了解了什么就是管道通信机制,实现了程序进程间得通信.积极通过合作,完成任务。目录TOC\o”1-3"\h\z\uHYPERLINK\l_Toc2301第一章:系统环境 PAGEREF_Toc23014HYPERLINK\l_Toc73101、1硬件环境 PAGEREF_Toc73104HYPERLINK\l_Toc316471、2软件环境ﻩPAGEREF_Toc316474HYPERLINK\l_Toc22541第二章:设计目得 PAGEREF_Toc225414HYPERLINK\l_Toc16656第三章:总体设计 PAGEREF_Toc166565HYPERLINK\l_Toc24493、1程序设计组成框图ﻩPAGEREF_Toc24495HYPERLINK\l_Toc271683、2流程图ﻩPAGEREF_Toc271686HYPERLINK\l_Toc31123、2、1匿名管道通信C/S流程图ﻩPAGEREF_Toc31126HYPERLINK\l_Toc176983、2、2命名管道通信C/S流程图ﻩ986HYPERLINK\l_Toc15984第四章:详细设计ﻩPAGEREF_Toc159848HYPERLINK\l_Toc85804、1匿名管道通信 PAGEREF_Toc85808HYPERLINK\l_Toc85804、2命名管道通信ﻩ10HYPERLINK\l_Toc6206第五章:调试与测试 13HYPERLINK\l_Toc28002第六章:设计中遇到得问题及解决方法ﻩ15HYPERLINK\l_Toc13935第七章:源程序清单与执行结果及分析ﻩPAGEREF_Toc1393516HYPERLINK\l_Toc25742第八章:总结 20HYPERLINK\l_Toc22097第九章:参考文献ﻩPAGEREF_Toc2209720:系统环境1、1硬件环境Intel(R)Core™2DuoCPUE75002、93GHz2、00GB内存1、2软件环境1)MicrosoftWindowsXPProfessional版本2002ServicePack32)VmwareWorkstation10、0、1build—13797763)RedHatLinux9:设计目得实践操作系统原理知识,根据题目要求设计、实现进程得管道通信,并且在虚拟机中模拟得linux系统中运行检测。:总体设计3、1程序设计组成框图无名管道读写示意图命名管道操作示意图3、2流程图3、2、1匿名管道通信C/S流程图3、2、2命名管道通信C/S流程图FIFO写进程::详细设计4、1匿名管道通信管道用于不同进程间通信。通常先创建一个管道,再通过fork函数创建一个子进程,该子进程会继承父进程创建得管道。注意事项:必须在系统调用fork()前调用pipe(),否则子进程将不会继承文件描述符。否则,会创建两个管道,因为父子进程共享同一段代码段,都会各自调用pipe(),即建立两个管道,出现异常错误。1、fork()创建一个新进程.用法: intfork()其中返回int取值意义如下:0:创建子进程,从子进程返回得id值〉0:从父进程返回得子进程id值—1:创建失败2、lockf()用作锁定文件得某些段或者整个文件.头文件:#includeﻩ<unistd、h>参数定义:intlockf();int;longsize;其中:files就是文件描述符;function就是锁定与解锁;1表示锁定;0表示解锁;Size就是锁定或解锁得字节数,若用0,表示从文件得当前位置到文件尾。3、read功能:从描述符为得文件读信息。用法:#include<unistd、h>ssize_t read(int,void*buff,size_tnbytes);返回:读到得字节数,若已到文件尾为0,若出错为-1。在UNIX/Linux可重定义为:intﻩread(intfd,char*buff,unsignednbytes);4、write功能:向已打开得文件写数据.用法:#include<unistd、h〉ssize_twrite(int,constvoid*buff,size_tnbytes);返回值:若成功为已写入得字节数;出错为-1.intﻩwrite(intfd,char*buff,unsignednbytes);文件位置指针文件位置指针:每个打开文件都有一个与其相关联得“当前位移量”.就是从文件开始处计算得字节数.通常,读、写操作都从当前文件位置处开始,并使位移量增加所读或写得字节数。按系统默认,当打开一个文件时,除非指定O_APPEND选择项,否则该位移量被设置为0,即指向文件得开始处。文件位置指针可以通过系统调用lseek来移动.#include〈unistd、h〉#include〈sys/types、h>#include〈errno、h〉#include〈stdio、h〉#include<string、h〉#include〈stdlib、h〉/**程序入口**/intmain(){intpipe_fd[2];pid_tpid;charbuf_r[100];char*p_wbuf;intr_num;memset(buf_r,0,sizeof(buf_r));//对较大得HYPERLINK"”结构体或HYPERLINK""数组进行清零操作得一种最快方法/*创建管道*/if(pipe(pipe_fd)<0){printf(”pipecreateerror\n");return—1;}/*创建子进程*/if((pid=fork())==0)//子进程执行序列{printf("\n”);close(pipe_fd[1]);//子进程先关闭了管道得写端sleep(2);/*让父进程先运行,这样父进程先写子进程才有内容读*/if((r_num=read(pipe_fd[0],buf_r,100))>0){printf(”%dnumbersreadfromthepipeis%s\n",r_num,buf_r);}close(pipe_fd[0]);exit(0);}elseif(pid>0)//父进程执行序列{close(pipe_fd[0]);//父进程先关闭了管道得读端if(write(pipe_fd[1],"Hello",5)!=—1)printf("parentwrite1Hello!\n”);if(write(pipe_fd[1],"Pipe”,5)!=—1)printf(”parentwrite2Pipe!\n");close(pipe_fd[1]);waitpid(pid,NULL,0);/*等待子进程结束*/exit(0);}return0;}4、2命名管道通信

命名管道:命名管道与无名管道基本相同,但也有不同点:无名管道只能有父进程使用;但就是通过命名管道,不相关得进程也能交换数据。1、创建用mkfifo或mknod创建一个命名管道。以mkfifo为例:ﻩ#includeﻩ<sys/types、h>ﻩ#include <sys/stat、h>ﻩintmkfifo(constchar*fifo_name,mode_tmode); ﻩ//成功返回0,否则为—12、使用 管道一经创建,就可向普通文件一样使用.可通过系统调用open,close,read,write,unlink等进行操作。FIFO读进程:#include<sys/types、h>#include〈sys/stat、h>#include<errno、h〉#include<fcntl、h>#include<stdio、h>#include〈stdlib、h〉#include<string、h>#defineFIFO"myfifo"/*程序入口*/intmain(intargc,char**argv){charbuf_r[100];intfd;intnread;printf(”Preparingforreadingbytes、、、\n");memset(buf_r,0,sizeof(buf_r));/*打开管道*/fd=open(FIFO,O_RDONLY|O_NONBLOCK,0);if(fd==-1){perror("open");exit(1);}while(1){memset(buf_r,0,sizeof(buf_r));if((nread=read(fd,buf_r,100))==-1){if(errno==EAGAIN)printf(”nodatayet\n”);}printf("read%sfromFIFO\n",buf_r);sleep(1);}/*后面三句话就是不会被运行到得,但不会影响程序运行得效果当程序在上面得死循环中执行时收到信号后会马上结束运行而没有执行后面得三句话。*/close(fd);//关闭管道pause();//暂停,等待信号unlink(FIFO);//删除文件}FIFO写进程:#include<sys/types、h〉#include<sys/stat、h>#include〈errno、h>#include<fcntl、h>#include〈stdio、h〉#include<stdlib、h〉#include<string、h>#defineFIFO_SERVER"myfifo”/**程序入口**/intmain(intargc,char**argv){intfd;charw_buf[100];intnwrite;/*创建有名管道*/if((mkfifo(FIFO_SERVER,O_CREAT|O_EXCL|O_RDWR)<0)&&(errno!=EEXIST)){printf("cannotcreatefifoserver\n");}/*打开管道*/fd=open(FIFO_SERVER,O_WRONLY|O_NONBLOCK,0);if(fd==-1){perror("open");exit(1);}/*入参检测*/if(argc==1){printf("Pleasesendsomething\n");exit(—1);}strcpy(w_buf,argv[1]);/*向管道写入数据*/if((nwrite=write(fd,w_buf,100))==-1){if(errno==EAGAIN)printf(”TheFIFOhasnotbeenreadyet、Pleasetrylater\n");}else{printf("write%stotheFIFO\n”,w_buf);}close(fd);//关闭管道return0;}:调试与测试运行匿名管道通信以及运行命名管道通信读进程结果如下:打开另外一个终端,运行写进程结果如下:同时读进程结果发生变化如下::设计中遇到得问题及解决方法1、由于课程涉及UNIX管道通信模式较少,刚开始做课程设计时感觉无从下手,后来通过瞧书以及上网查询相关资料有些头绪。2、对于虚拟机与主机得交互搞了好久但就是最后结果不理想,也没搞成功,试了用ftp方式相互连接,以及通过VMwareTools也没有成功。后来,通过问学长与同学终于解决了。通过此事,我知道知识自己主动探索实践固然好,但学习她人已有得经验学得知识更多更快。3、对于C语言中open、write等函数掌握得并不好,这就是由于长期不联系C语言所致,一门语言要想精通必须通过不断得联系才行。:源程序清单与执行结果及分析任务1:匿名管道通信#include<unistd、h〉#include〈sys/types、h>#include〈errno、h〉#include〈stdio、h>#include〈string、h〉#include<stdlib、h>/**程序入口**/intmain(){intpipe_fd[2];pid_tpid;charbuf_r[100];char*p_wbuf;intr_num;memset(buf_r,0,sizeof(buf_r));/*创建管道*/if(pipe(pipe_fd)〈0){printf("pipecreateerror\n”);return—1;}/*创建子进程*/if((pid=fork())==0)//子进程执行序列{printf("\n");close(pipe_fd[1]);//子进程先关闭了管道得写端sleep(2);/*让父进程先运行,这样父进程先写子进程才有内容读*/if((r_num=read(pipe_fd[0],buf_r,100))〉0){printf(”%dnumbersreadfromthepipeis%s\n”,r_num,buf_r);}close(pipe_fd[0]);exit(0);}elseif(pid>0)//父进程执行序列{close(pipe_fd[0]);//父进程先关闭了管道得读端if(write(pipe_fd[1],”Hello”,5)!=—1)printf("parentwrite1Hello!\n”);if(write(pipe_fd[1],"Pipe",5)!=—1)printf("parentwrite2Pipe!\n");close(pipe_fd[1]);waitpid(pid,NULL,0);/*等待子进程结束*/exit(0);}return0;}任务2:命名管道通信FIFO读进程:#include<sys/types、h>#include〈sys/stat、h〉#include<errno、h〉#include〈fcntl、h>#include<stdio、h>#include<stdlib、h〉#include<string、h>#defineFIFO”/tmp/myfifo”/*程序入口*/intmain(intargc,char**argv){charbuf_r[100];intfd;intnread;printf(”Preparingforreadingbytes、、、\n”);memset(buf_r,0,sizeof(buf_r));/*打开管道*/fd=open(FIFO,O_RDONLY|O_NONBLOCK,0);if(fd==-1){perror(”open”);exit(1);}while(1){memset(buf_r,0,sizeof(buf_r));if((nread=read(fd,buf_r,100))==-1){if(errno==EAGAIN)printf("nodatayet\n");}printf(”read%sfromFIFO\n",buf_r);sleep(1);}/*后面三句话就是不会被运行到得,但不会影响程序运行得效果当程序在上面得死循环中执行时收到信号后会马上结束运行而没有执行后面得三句话。*/close(fd);//关闭管道pause();//暂停,等待信号unlink(FIFO);//删除文件}FIFO写进程:#include<sys/types、h〉#include<sys/stat、h>#include<errno、h>#include〈fcntl、h>#include〈stdio、h>#include〈stdlib、h>#include〈string、h〉#defineFIFO_SERVER”/tmp/myfifo"/**程序入口**/intmain(intargc,char**argv){intfd;charw_buf[100];intnwrite;/*创建有名管道*/if((mkfifo(FIFO_SERVER,O_CREAT|O_EXCL|O_RDWR)<0)&&(errno!=EEXIST)){

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论