哎嗨,又进来抄作业来了? 都抓起来。
开个玩笑,往下看吧。
实验二:进程控制(8学时)
实验要点
了解系统调用fork()、exec()和wait()的功能和实现过程。
实验内容
1、 编写一段程序,使用系统调用fork()来创建两个子进程,并由父进程重复显示字符串“parent:”和自己的标识数,而子进程则重复显示字符串“child:”和自己的标识数。
下面是我的代码:
下面是几次的运行结果:
说明:在几次结果中会在结果的输出中有一条特殊,出现目录行,而在最后一行却不再出现,只是空白行。对此我的猜想是对绿色行的输出也可以看作是一个进程,在程序运行过程中它与程序进程一起竞争CPU,所以才会出现这种情况。
在运行中首先会输出父进程的Pid,之后开始创建第一个子进程,在创建第二个子进程的时候第一个子进程也会进行创建,所以最终会出现一个父进程,两个子进程,一个孙进程。而在子进程创建孙进程时fork会返回两个值,一个是在子进程中显示孙进程的Pid,一个是孙进程中显示0表示进程创建成功,所以会有出现两次相同标识符的时候。
2、 编写一段程序,使用系统调用fork()来创建一个子进程。子进程通过系统调用execvp()更换自己的执行代码,新的代码显示“new program.”。而父进程则调用wait()等待子进程结束,并在子进程结束后显示子进程的标识符,然后正常结束。
首先我们先写一个1.c的文件并完成编译
在创建jincheng2.c的文件,这里是我的代码部分:
运行结果:
说明:在本题中,首先展示了父进程的Pid为34524,之后创建子进程,因为fork会返回两个结果,父进程中p是子进程的pid,子进程中p=0,所以我们用p来判断是父进程还是子进程。
在子进程中我们首先展示子进程的pid,并利用execle执行程序 1 来输出字符串 new programe。(这里没用execvp是因为没掌握明白,虽然个人感觉应该是差不多的,但确实还没弄对。)在父进程中展示子进程pid并进行等待,等待结束后再执行。
所以我们的运行结果中,首先创建子进程,pid是34525。父进程先争夺到cpu在展示过后进行等待,子进程获得cpu并执行1程序,完成字符串输出。父进程在子进程执行结束后重新获得cpu,进行后续的执行。
下面是网盘代码啊:
链接:https://pan.baidu.com/s/1ct2tgKuORnZ5UAzNqWWQEA
提取码:1234