文档详情

linux操作系统实验报告.doc

发布:2017-02-12约6.81千字共13页下载文档
文本预览下载声明
设计题目 进程管理及理解和增加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);
显示全部
相似文档