- 1、本文档共13页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)