您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 公司方案 > 《Linux操作系统》实验报告模板
课程编号:B080103040Linux操作系统实验报告姓名姚柯杰学号20126266班级软工1212指导教师石凯实验名称Linux操作系统实验开设学期2014-2015第一学期开设时间第11周——第18周报告日期评定成绩评定人石凯评定日期东北大学软件学院实验一熟悉Linux环境一、举例列出常用的shell命令使用方法1.目录操作(1)mkdirabc创建一个目录abc(2)cd/abc将工作目录改变到abc(3)cd改变当前目录到主目录(4)ls列出当前目录的内容(5)ls-l输出当前目录内容的长列表,每个目录或文件占一行(6)pwd显示当前目录的全路径2.文件显示实用程序(1)catmx.c显示mx.c文件内容(2)moremx.c分屏显示mx.c内容(3)catfile1file2连接file1和file23文件管理实用程序(1)cpfile1file2将文件1复制到文件2(2)mvfile1file2将文件重命名为file2(3)rmfilename删除文件filename二、通过实例写出Linux下C程序编辑运行过程。在终端命令下输入vifilename命令,这里我输入vihelloworld.c创建并打开helloworld.c文件按i进入编辑模式,输入下列code:#includestdio.hvoidmain(void){Printf(“helloworld!\n”);}输入:wq保存退出输入cchelloworld.c编译,在输入./a.out运行三、实验总结在实验一中,我初步对linux有了初步的了解,能熟练目录和文件进行操作,并且能用linux进行基本简单的基于c的编程。师傅领进门,修行在个人,算是通过这个实验进入了linux的门。实验二文件操作一、实现CP命令实现思路:提取出源路径和目标路径到函数中,放于定义的两个int变量,定义缓冲区buf,对两个变量进行判断,如果符合要求打开读取源文件信息存于缓冲区,然后写到目标文件中,关闭两个文件以实现等同cp效果。此处以hello。C文件为源文件,目标文件1.c。在调试cp命令中,由于一开始并未定义缓冲区,导致程序出错,后假如缓冲区,程序得以正常运行。二、实现ls命令实现思路:调用dirent.h来实现打开目录流,定义变量,随后对变量进行判定用opendir、readdir打开并读取目录流,将值传递给另一个变量,打印出来。编译源程序并运行:在实现ls命令中使用man手册查找需要的dir等目录流信息,man是个强大的命令,在编程的过程中由于疏忽一开始并未假如判断条件,有些突发情况会难以处理,最后通过课件修过过来。三、设备文件操作鼠标对应的设备文件是/dev/input/mice实验三进程间通信(一)进程的创建(必做题)编写一段程序,使用系统调用fork()创建两个子进程,在系统中有一个父进程和两个子进程活动。让每个进程在屏幕上显示一个字符;父进程显示字符“a”,子进程分别显示字符“b”和“c”。试观察记录屏幕上的显示结果,并分析原因。创建一个新的子进程。其子进程会复制父进程的数据与堆栈空间。Fork成功则在父进程会返回新建立的子进程pid,而在新建立的子进程中则返回0。如果fork失败则直接返回-1。所以在循环条件上出现上述情况。修改已编写的程序,将每个进程的输出由单个字符改为一句话,再观察程序执行时屏幕上出现的现象,并分析其原因。(必做题)子进程创建成功,到下一个while,第二个子进程成功到最后循环,输入parents1-500,随后返回继续上面子进程的循环输出。【思考题】1.系统是怎样创建进程的?答:在UNIX系统中,只有0进程是在系统引导时被创建的,在系统初启时由0进程创建1进程,以后0进程变成对换进程,1进程成为系统中的始祖进程。UNIX利用fork()为每个终端创建一个子进程为用户服务,每个终端进程又可利用fork()来创建其子进程,从而形成一棵进程树。2.当前运行的程序(主进程)的父进程是什么?建立如下的c文件来获取pid得到这三个进程pid,可见父进程的pid是5182。(二)信号量机制实验【实验内容】1.编写一段程序,使用系统调用fork()创建两个子进程,再用系统调用signal()让父进程捕捉键盘上来的中断信号(即按ctrl+c键),当捕捉到中断信号后,父进程用系统调用kill()向两个子进程发出信号,子进程捕捉到父进程发来的信号后,分别输出下列信息后终止:Childprocess1iskilledbyparent!Childprocess2iskilledbyparent!父进程等待两个子进程终止后,输出以下信息后终止:Parentprocessiskilled!实验要求:⑴运行程序并分析结果。⑵如果把signal(SIGINT,stop)放在①号和②号位置,结果会怎样并分析原因。⑶该程序段前面部分用了两个wait(0),为什么?⑷该程序段中每个进程退出时都用了语句exit(0),为什么?程序代码:#includestdio.h#includestdlib.h#includesignal.h#includeunistd.h#includesys/types.h#includesys/wait.hintwait_mark;voidwaiting(),stop();voidmain(){intp1,p2;signal(SIGINT,stop);while((p1=fork())==-1);if(p10){//while((p2=fork())==-1);if(p20){//wait_mark=1;waiting(0);kill(p1,10);kill(p2,12);waiting();waiting();printf(parentprocessiskilled!\n);exit(0);}else{wait_mark=1;signal(12,stop);waiting();lockf(1,1,0);printf(childprocess2iskilledbyparent!\n);lockf(1,0,0);exit(0);}}else{wait_mark=1;signal(10,stop);waiting();lockf(1,1,0);printf(childprocess1iskilledbyparent!\n);lockf(1,0,0);exit(0);}}voidwaiting(){while(wait_mark!=0);}voidstop(){wait_mark=0;}(1)当按下ctrl+c中断进程时,程序将执行,父进程打印消息,父进程kill子进程,子进程1收到消息上锁,打印消息,然后解锁关闭进程,随后子进程2同样操作,在kill子进程后父进程打印消息,中断自身进程。(2)运行后表面并没有任何改变,在两处加入代码之后,偶尔会出现需要在中断第一次进程后需要进行第二次中断。在添加两个中段接受指令后,会先执行关于子进程的代码片段。(3)答:父进程为子进程收尸,防止僵尸程序出现。(4)答:在调用处强行退出程序,运行一次程序就结束。(三)进程的管道通信实验(四)【实验内容】1.编制一段程序,实现进程的管道通信。使用pipe()建立一条管道线。两个子进程p1和p2分别向管道各写一句话:Child1issendingmessage!Child2issendingmessage!而父进程则从管道中读出来自于两个子进程的信息,显示在屏幕上。实验要求:运行程序并分析结果。2.在父进程中用pipe()建立一条管道线,往管道里写一句话,两个子进程接收这句话。定义缓冲区,创建管道,随后创建进程,将父进程的消息写进缓冲去写进管道再传给写进子进程,子进程接受。定义一个管道,父进程传递消息到管道,随后创建两个子进程接收这个消息,然后结束进程。实验小结:再这个实验中一开始打算将两个子进程分开判断,但是常常最后出现结果不是出现僵尸进程就是跳过其中一个子进程结束,最后我觉得既然两个进程同时创建,不如直接将他们一起进行判断。(四)消息的发送与接收实验【实验内容】1.消息的创建、发送和接收。使用系统调用msgget(),msgsnd(),msgrev(),及msgctl()编制一长度为1k的消息发送和接收的程序。参考程序①client.c#includesys/types.h#includesys/msg.h#includesys/ipc.h#defineMSGKEY75structmsgform{longmtype;charmtext[1000];}msg;intmsgqid;voidclient(){inti;msgqid=msgget(MSGKEY,0777);for(i=10;i=1;i--){msg.mtype=i;printf(“(client)sent\n”);msgsnd(msgqid,&msg,1024,0);}exit(0);}main(){client();}②server.c#includesys/types.h#includesys/msg.h#includesys/ipc.h#defineMSGKEY75structmsgform{longmtype;charmtext[1000];}msg;intmsgqid;voidserver(){msgqid=msgget(MSGKEY,0777|IPC_CREAT);do{msgrcv(msgqid,&msg,1030,0,0);printf(“(server)received\n”);}while(msg.mtype!=1);msgctl(msgqid,IPC_RMID,0);exit(0);}main(){server();}1.列出调试通过程序的清单,分析运行结果。首先运行client.c创建打开消息队列75,往消息对列中传递消息10-1,然后运行serve.c,打开消息队列75,然后接收其中的消息直到消息为假(不存在),退出进程。2.给出必要的程序设计思路和方法(或列出流程图)。先后fork两个子进程,server和client,进行通信。Server端建立一个key为75的消息队列,等待其他进程发来的消息。当遇到类型为1的消息,则作为结束的信号,取消该队列,并退出server。Server每接受到一个消息后显示一句“(server)received”。3.总结上机调试过程中所遇到的问题和解决方法及感想。无法做到同步,再client进程全部发送完成后,serve进程才开始进行接收消息并打印,按照常理来说应该是发消息接消息的,试了其他办法却老是出现僵尸进程。实验四编写Web服务器运行Web服务器:编译程序,并在某个端口(建议用80)运行它:$ccwebserv.csocklib.c–owebserv$./webserv80现在可以访问Web服务器,网址为。将html文件放到该目录中并用来打开它。创建下面的shell脚本:#!/bin/shprintf“Content-type:text/plain\n\nhello\n”;将它命名为hello.cgi,用chmod改变权限为755,然后用浏览器调用该程序:。评价表格考核标准得分(1)正确理解和掌握实验所涉及的概念和原理(20%);(2)按实验要求合理设计数据结构和程序结构(20%);(3)能设计测试用例,运行结果正确(20%);(4)认真记录实验数据,原理及实验结果分析准确(20%);(5)实验过程中,具有严谨的学习态度和认真、踏实、一丝不苟的科学作风(5%);(6)所做实验具有一定的创新性(5%);(7)实验报告规范(10%)。
本文标题:《Linux操作系统》实验报告模板
链接地址:https://www.777doc.com/doc-7352651 .html