课程目的:
熟悉进程环境、进程生命周期
进程控制:
1.创建进程
#include <unistd.h>
pid_t fork(void);
创建进程:
函数执行后,系统会创建一个与原进程几乎相同的进程,之后父子进程都继续执行
返回值说明:
成功:返回两个值,子进程创建成功后,原程序会被复制,就有了两个fork函数。父进程的fork函数会返回子进程的pid,子进程的fork函数会返回0。
不成功:若子进程创建失败,原程序不会复制,父进程的fork函数返回-1。
2.创建多个进程
创建多个子进程,进行简单的循环即可
int i;
for(i = 0; i < 2; i ++){
tempPid = fork();
}//of for i
每次调用fork函数,系统会复制原程序
i=0,第一次循环,会有两份test_fork文件
i=1,第二次循环,第一份test_fork文件又会有两份test_fork文件,第二份test_fork文件也会有两份
每一次循环,进程的总数是当前进程数量的两倍,2次循环则为4个进程
提示:
在Linux系统中,子进程应由父进程回收,但是当子进程被创建后,它与它的父进程及其它进程共同竞争系统资源,所以父子进程执行的顺序是不确定的,终止的先后顺序也是不确定的。
Shell命令提示符也是1个进程,它需要和新建进程一起竞争CPU
3.进程的执行顺序:利用sleep函数,暂缓进程执行
sleep():
令目前的进程暂停, 直到达到参数seconds 所指定的时间, 或是被信号所中断
#include <unistd.h>
unsigned int sleep(unsigned int seconds);
案例:
test_fork3.c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(){
pid_t tempPid;
int i;
for(i = 0; i < 2; i ++){
if((tempPid = fork()) == 0){
break;
}//of if
}//of for i
if(tempPid == -1){
perror("fork error");
}else if(tempPid > 0){//parent
sleep(2);
printf("parent process, pid = %d, ppid = %d\n", getpid(), getppid());
}else{//child
sleep(i);
printf("I am child process = %d, pid = %d, ppid = %d\n", i + 1, getpid(), getppid());
}//of if
printf("......finish......");
return 0;
}//of main