linux操作系統实验报告.doc

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
linux操作系統实验报告

设计题目 进程管理及理解和增加Linux系统调用 设计时间和地点 设计时间:2011年12月26日——2011年12月29日 设计地点:装备制造学院B座502机房 设计目的和要求 (1)加深对进程概念的理解,明确进程和程序的区别。 (2)进一步认识并发执行的实质。 (3)分析进程争用资源的现象,学习解决互斥的方法。 (4)了解Linux系统中进程通信的基本原理。 (5)弄清进程管理在操作系统中的地位和作用。 (6) 初步揭开Linux内核的神秘“面纱”,为今后深入学习内核原理打下基础。 (7)弄清系统调用原理,以及操作系统在处理每个系统调用的时候,用户态怎样切入核心态?又怎样从核心态返回到用户态的? 四、设计内容 (1)实验准备 a. 基本头文件 sys/types.h:类型头文件,定义了基本的系统数据类型。unistd.h:定义了各种符号常数和类型,并声明了各种函数。stdio .h带缓冲的标准输入输出!tdlib.h头文件即standard library标准库头文件[root@localhost ~]# vi filename Command 模式是vi默认模式,如果我们处于其它命令模式时,当我们按ESC键后,接着再输入:号时,vi会在屏幕的最下方等待我们输入命令; :w 保存; :w filename 另存为filename; :wq! 保存退出; :wq! filename 注:以filename为文件名保存后退出; :q! 不保存退出; c.gcc的基本使用 1、直接编译 gcc filename.c -o filename 2、分步编译 进行预编译# gcc -E hello.c -o hello.i 生成目标代码# gcc -c hello.i -o hello.o 链接成可执行文件# gcc hello.o -o hello d.U盘的挂载与卸载 先要为外挂点新建一个子目录,一般外挂点的子目录都是建立在/mnt里面的,也建在那里,当然也可以建在/目录下,名字可以自己定,就取名为usb,终端下的命令如下:mkdir /mnt/usb 然后接上U盘了,在终端下输入mount /dev/sdb1 /mnt/usb命令并击Enter 删除挂起点,方法是:umount /dev/sdb1 /mnt/usb 或 umount /dev/sdb1 (2)设计内容 1、进程的创建 编写一段程序,使用系统调用fork()创建两个子进程。当此程序运行时,在系统中有一个父进程和两个子进程活动。让每一个进程在屏幕上显示一个字符:父进程显示“A”;子进程分别显示字符“b”和“c”。试观察记录屏幕上的显示结果,并分析原因。 a、程序代码: #includestdio.h #includestdlib.h #includesys/types.h #includeunistd.h main() { if(fork()==0) { printf(进程b 该进程的ID号为:%d\n,getpid()); exit(0); } else { if(fork()==0) { printf(进程c 该进程的ID号为:%d\n,getpid()); exit(0); } printf(进程a 该进程的ID号为:%d\n,getpid()); exit(0); } } b、程序解释 fork()函数: 功能:创建一个新进程。 格式:int fork() 返回值: ·0:创建子进程,从子进程返回的id值 ·大于0:从父进程返回的了进程id值 ·-1:创建失败 getpid()函数:getpid函数用来取得目前进程的进程识别码,许多程序利用取到的此值来建立临时文件#includestdio.h #includesignal.h #includeunistd.h #includestdlib.h main() { int p1,p2,i; if(p1=fork()){ lockf(1,1,0); printf(子进程2已创建!!\n); exit(0); } else{ if(p2=fork()) printf(子进程1已创建!!\n); exit(0); else printf(父进程已经创建!!\n); exit(0); } } 结果截图 结果分析 成功显示一段话,其中循序与进程的调度机制有关 加入lockf()函数后 #includestdio.h #includesignal.h #includeunistd.h #includestdlib.h main() { int p1,p2,i; if(p1=fork()){ lockf(1,1,0); p

文档评论(0)

fv45ffsjjI + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档