欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    操作系统实验报告.docx

    • 资源ID:8102890       资源大小:18.58KB        全文页数:10页
    • 资源格式: DOCX        下载积分:12金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要12金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    操作系统实验报告.docx

    1、操作系统实验报告操作系统实验报告 学 号: 姓 名: 指导老师: 完成日期: 实验一 1实验二 2实验三 7实验四 10实验五 15实验六 18实验七 22实验一 UNIX/LINUX入门一、实验目的了解 UNIX/LINUX 运行环境,熟悉UNIX/LINUX 的常用基本命令,熟悉和掌握UNIX/LINUX 下c 语言程序的编写、编译、调试和运行方法。二、实验内容 熟悉 UNIX/LINUX 的常用基本命令如ls、who、pwd、ps 等。练习 UNIX/LINUX的文本行编辑器vi 的使用方法熟悉 UNIX/LINUX 下c 语言编译器cc/gcc 的使用方法。用vi 编写一个简单的显示“

    2、Hello,World!”c 语言程序,用gcc 编译并观察编译后的结果,然后运行它。三、实验要求按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验报告。四、实验程序#include #include int main() printf (Hello World!n); return 0;五、实验感想通过第一次室验,我了解 UNIX/LINUX 运行环境,熟悉了UNIX/LINUX 的常用基本命令,熟悉和掌握了UNIX/LINUX 下c 语言程序的编写、编译、调试和运行方法。实验二 进程管理一、实验目的加深对进程概念的理解,明确进程与程序的区别;进一步认识并

    3、发执行的实质。二、实验内容(1)进程创建编写一段程序,使用系统调用fork()创建两个子进程。当此程序运行时,在系统中有一个父进程和两个子进程活动。让每一个进程在屏幕上显示一个字符:父进程显示“a“;子进程分别显示字符”b“和字符“c”。试观察记录屏幕上的显示结果,并分析原因。(2)进程控制修改已编写的程序,将每一个进程输出一个字符改为每一个进程输出一句话,再观察程序执行时屏幕上出现的现象,并分析原因。(3)进程的管道通信编写程序实现进程的管道通信。使用系统调用pipe()建立一个管道,二个子进程P1 和P2 分别向管道各写一句话:Child 1 is sending a message!Ch

    4、ild 2 is sending a message!父进程从管道中读出二个来自子进程的信息并显示(要求先接收P1,再接收P2)。三、实验要求按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验报告。四、实验设计 1、功能设计(1)进程创建使用fork()创建两个子进程,父进程等待两个子进程执行完再运行。(2)进程控制使用fork()创建两个子进程,父进程等待两个子进程分别输出一句话再运行。(3)进程的管道通信 先创建子进程1,向管道写入一句话,子进程1结束后创建子进程2,向管道写入一句话,最后父进程从管道中读出。 2、数据结构 子进程和管道。 3、程序框图

    5、五、实验程序(1)进程创建#include#includeint main() int pid1, pid2; pid1=fork(); if (pid10) wait(NULL); pid2 = fork(); if (pid20) wait(NULL);printf(an);exit(0); (2)进程控制#include#includeint main() int pid1, pid2; pid1=fork(); if (pid10) wait(NULL); pid2 = fork(); if (pid20) wait(NULL); printf(This is father an);

    6、exit(0); (3)进程的管道通信#include#include#include#includeint main() int pid1, pid2; int pfd2; char *msg1=Child 1 is sending a message!; char *msg2=Child 2 is sending a message!; char buf256; int r,w; if(pipe(pfd)0) printf(pipe create error!n); exit(1); pid1 = fork(); if (pid10) printf(Fork 1 failed!); if

    7、(pid1=0) close(pfd0); Linux 支持的消息通信机制及其使用方法2. Linux 系统的共享存储区的原理及使用方法。二、实验内容1消息的创建、发送和接收使用消息调用 msgget()、msgsnd()、msggrev()、msgctrl()编制长度为1K 的消息的发送和接收程序。2共享存储取得创建、附接和断接使用系统调用 shmget()、shmat()、shmctl()、shmctl(),编制一个与上述功能相同的程序。三、实验要求按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验报告。四、实验设计1、消息的创建、发送和接收(1)功能设

    8、计为了实现进程之间消息的创建、发送和接收,首先应定义两个子进程,Server进程负责发送,Client进程负责接收,父进程负责创建。其次需要用到msgget()、msgsnd()、msggrev()、msgctrl()等函数进行对消息的控制。题目要求消息长度为1K,那么msgsnd(id,msgp,size, flag)和msgrcv(id,msgp,size,type,flag)函数中参数size应设为1024,msgget(key,flag)中的key应为75。父进程获得创建消息后,子进程Server先后发送编号为110的10条消息,子进程Client先后接收这10条消息,方能达到实验目的

    9、。(2)数据结构消息(mymsg):结构体实现,包含的成员变量有消息类型和消息内容,具体实现如下:struct mymsg shiyan5&后台运行此程序,使用kill USR1 2472时,子进程接收信号,信号处理程序输出子进程号0,并输出信号名称。七、实验心得通过本次实验,我掌握了注册信号处理程序及signal()调用方法,并且了解了如何让程序在后台运行的方法。我也进一步了解了LINUX系统中进程同步与通信的原理。 实验六 线程的创建一、实验目的编写 Linux 环境下的多线程程序,了解多线程的程序设计方法,掌握最常用的三个函数pthread_create,pthread_join 和pt

    10、hread_exit 的用法。二、实验内容1、主程序创建两个线程 myThread1 和myThread2 ,每个线程打印一句话。使用pthread_create(&id,NULL,(void *) thread,NULL)完成。 2、创建两个线程,分别向线程传递如下两种类型的参数 传递整型值 传递字符三、实验要求按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验报告。四、实验设计1、创建两个进程每个进程打印一句话(1)功能设计题目要求创建两个线程,每个线程打印一句话,可以认为两个线程的功能是相同的,故只需要写一个线程的运行函数thread(),在这个函数里

    11、有一个printf输出一句话即可。然后在main函数里分别创建两个线程,然后等待两个线程结束。(2)数据结构线程:使用pthread_create()创建。每个线程有相应的线程标示符,也有各自的属性。线程可以和线程运行函数绑定,并可以在创建线程时确定该线程运行函数的参数。(3)程序框图2、创建两个进程每个进程打印一句话分别向线程传递如下两种类型的参数 :整型值、字符(1)功能设计题目要求创建两个线程,两个线程分别传递int型和char型数据给线程运行函数。所以要编写两个不同的线程运行函数分别接收int型和char型的数据。相应的pthread_create()函数中要给第四个参数,作为形参传进

    12、线程运行函数。(2)数据结构线程:同1,使用pthread_create()创建。每个线程有相应的线程标示符,也有各自的属性。线程可以和线程运行函数绑定,并可以在创建线程时确定该线程运行函数的参数。(3)程序框图五、实验程序1、创建两个进程每个进程打印一句话#include #include#include void thread() n); n); pthread_join(id1,NULL); n); pthread_join(id1,NULL); /等待线程1结束 pthread_join(id2,NULL); /等待线程2结束 return (0);六、实验结果由图可知两个线程主程序创

    13、建了两个进程这两个进程分别输出了一句话。主程序分别创建了两个线程并向线程1传递了t向线程2传递了99,线程运行函数分别输出告知接收了这两个参数。七、实验感想通过本次实验,我学会了如何使用LINUX下的线程创建函数pthread_create()来创建线程,并且向线程传递参数。同时更加熟练的使用LINUX。实验七 利用信号量实现进程的控制一、实验目的学习 UNIX 类操作系统信号量机制,编写Linux 环境下利用信号量实现进程控制的方法,掌握相关系统调用的使用方法。二、实验内容创建4 个线程,其中两个线程负责从文件读取数据到公共的缓冲区,另两个线程从缓冲区读取数据作不同的处理(加和乘运算)。使用

    14、信号量控制这些线程的执行。三、实验要求按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验报告。四、实验设计1、功能设计题目要求创建4个线程,其中两个负责从文件读数据到缓冲区,另两个负责从缓冲区读数据进行加和乘的运算。我对这4个线程进行如下安排,线程1读后线程2才可以读,线程2读了后线程3才可以进行加的运算,线程3加完了后线程4才能进行乘的运算,线程4乘完后线程1才能继续读。故需4个信号量sem1,sem2,sem3,sem4。线程1消费sem1生产sem2,线程2消费sem2生产sem3,线程3消费sem3生产sem4,线程4消费sem4生产sem1,形成一

    15、个循环,直到文件结束为止。2、数据结构信号量(semaphore):数据类型为结构 sem_t,本质上是一个长整型的数。一共4个公共缓冲区(stack):采用2维数组的方式实现(stackNUM2)。数组中的两列分别存储两个文件中的数据。该2维数组还有一个索引:size,指向2维数组的顶部。读线程每次从文件读出两个数放到stackNUM0和stackNUM13、程序框图五、实验程序#include#include#include#define MAX 10int operandMAX2;int size=0;sem_t sem;void ReadData1(void) FILE *fp=fop

    16、en(,r); while(!feof(fp) fscanf(fp,%d %d,&operandsize0,&operandsize1); if (feof(fp) break; +size; sem_post(&sem); fclose(fp);void ReadData2(void) FILE *fp=fopen(,r); while(!feof(fp) fscanf(fp,%d %d,&operandsize0,&operandsize1); if (feof(fp) break; +size; sem_post(&sem); fclose(fp);void HandleData1(vo

    17、id) while(1) sem_wait(&sem); -size; printf(Plus:%d+%d=%dn,operandsize0,operandsize1, operandsize0+operandsize1); void HandleData2(void) while(1) sem_wait(&sem); -size; printf(Multiply:%d*%d=%dn,operandsize0,operandsize1, operandsize0*operandsize1); int main(void) pthread_t t1,t2,t3,t4; sem_init(&sem

    18、,0,0); pthread_create(&t3,NULL,(void *)ReadData1,NULL); pthread_create(&t1,NULL,(void *)HandleData1,NULL); pthread_create(&t4,NULL,(void *)ReadData2,NULL); pthread_create(&t2,NULL,(void *)HandleData2,NULL); pthread_join(t2,NULL); return 0;六、实验结果从图可知线程1从读两个数到缓冲区然后线程2从读两个数到缓冲区,然后线程3从缓冲区读出两个数相加,最后线程4再读出两个数相乘。七、实验感想通过本次实验,我进一步掌握了如何使用LINUX下的线程创建函数pthread_create()创建线程,并且学会了如何使用信号量控制进程的运行,学会了使用消费函数sem_wait(),生产函数sem_post(),以及如何初始化信号量,同时也掌握了文件的读取方法,本次实验加深了我对信号量的认识。


    注意事项

    本文(操作系统实验报告.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开