1 .实验内容
(1) 了解系统调用fork()、execvp()和wait()的功能和实现过程。
fork()创建一个子进程。
execvp():通俗的讲就是替换一段代码。
wait():wait()要与fork()配套出现,如果在使用fork()之前调用wait(),wait()的 返回值则为-1 正常情况下wait()的返回值为子进程的PID.
(2) 编写一段程序,使用系统调用fork()来创建两个子进程,并由父进程重复显示字符串“parent:”和自己的标识数,而子进程则重复显示字符串“child:”和自己的标识数。
#include<stdio.h>
#include<unistd.h>
int main()
{
if(fork()==0)
printf( " child ID :%d\n" ,getpid());
else
printf( "parant ID:%d\n " ,getpid());
}
(3) 编写一段程序,使用系统调用fork()来创建一个子进程。子进程通过系统调用execvp()更换自己的执行代码,新的代码显示“new program.”。而父进程则调用wait()等待子进程结束,并在子进程结束后显示子进程的标识符,然后正常结束。
#include<stdio.h>
#include<wait.h>
#include<unistd.h>
#include<sys/types.h>
int main()
{
if( fork()==0){
printf( " hello no.1\n" );
printf( " hello no. 2\n" );
char *agrv[]={"test1" ,0};
execvp("/home/lxt/test1",agrv);
printf("hello no.3\n" );
printf( "hello no.4\n");
}
else{
wait(0);
printf ( "this is parant,child ID:%d\n" ,getpid());
}
return 0;
}
#include<stdio.h>
int main()
{
printf("new program\n");
}
2 .思考
(1) 系统调用fork()是如何创建进程的?
fork()创建的是两个内容完全相同的进程,唯一不同的就是返回值。
父子进程的区别除了进程标志符(process ID)不同外,变量pid的值也不相同,pid存放的是fork的返回值。fork调用的一个奇妙之处就是它仅仅被调用一次,却能够返回两次,它可能有三种不同的返回值:
fork()返回新建的子进程ID, 子进程fork()返回0,
(2) 当首次将CPU 调度给子进程时,其入口在哪里?
子进程是从fork()后的语句开始执行(也就是新进程调用的入口)。
(3) 系统调用execvp()是如何更换进程的可执行代码的?
execvp()会从PATH 环境变量所指的目录中查找符合参数file 的文件名,找到后便执行该文件,然后将第二个参数argv传给该欲执行的文件。
(4) 对一个应用,如果用多个进程的并发执行来实现,与单个进程来实现有什么不同?
使用多个进程并发执行,则说明有许多个进程同时处理应用,比单个进程单独处理的效率要高,但是相对的并发执行消耗的资源页更多,要求也更高。