系统级程序设计第二课内容——Linux进程管理
一、进程管理
学习一个系统,学习进程是非常有必要的,主要是对并发程序的运行过程的管理,即对处理器的管理。其功能是跟踪和控制所有进程的活动,为分配和调度CPU,协调进程的运行步调。
二、fork()函数
1.函数介绍
创建进程;函数执行后,系统会创建一个与原进程几乎相同的进程,之后父子进程都继续执行
pid_t fork(void);
参数说明:无
返回值说明:
成功:返回两个值,子进程创建成功后,原程序会被复制,就有了两个fork函数。父进程的fork函数会返回子进程的pid,子进程的fork函数会返回0.
不成功:若子进程创建失败,原程序不会复制,父进程的fork函数返回-1。
注意:多次执行该函数会发现,child process后输出的ppid不等于parent process的pid,而等于1,是因为父进程先于子进程终止,子进程变成“孤儿进程”,后面由init进程来接收。
2.创建多个进程
代码如下(示例):
#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
printf("parent process , pid = %d , ppid = %d\n",getpid(),getppid());
}else{//child
printf("child process , pid = %d , ppid = %d\n",getpid(),getppid());
}//of if
printf("-------finish--------\n");
return 0;
}
运行结果如下:
在Linux系统中,子进程应由父进程回收,但是当子进程被创建后,它与它的父进程及其它进程共同竞争系统资源,所以父子进程执行的顺序是不确定的,终止的先后顺序也是不确定的。
参考文章:https://blog.csdn.net/search_129_hr/article/details/124477771