【Linux】——进程控制(上)
目录
一、前文
二、正文
1.进程创建
①fork函数初识
编辑
②fork函数返回值
③ 写时拷贝
④fork常规用法
⑤fork调用失败的原因
⑥如何一次创建多个进程
2.进程终止
①进程退出场景
②信号
③进程常见退出方法
三、小提问
四、结语
一、前文
本文会为大家带来进程中有关进程控制的讲解,重点是进程的创建和终止,希望大家能够从中有所收获。
二、正文
1.进程创建
①fork函数初识
在之前的讲解中我们已经见过了fork函数,在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。
#include
pid_t fork(void);
返回值:自进程中返回0,父进程返回子进程id,出错返回-1
进程调用fork,当控制转移到内核中的fork代码后,内核做:
●分配新的内存块和内核数据结构给子进程
●将父进程部分数据结构内容拷贝至子进程
●添加子进程到系统进程列表当中
●fork返回,开始调度器调度
当一个进程调用fork之后,就有两个二进制代码相同的进程。而且它们都运行到相同的地方。但每个进程都将可以 开始它们自己的旅程,看如下程序。
#include
pid_t fork(void);
返回值:自进程中返回0,父进程返回子进程id,出错返回-1
int main( void )
{
pid_t pid;
printf("Before: pid is %d
", getpid());
if ( (pid=fork()) == -1 )perror("fork()"),exit(1);
printf("After:pid is %d, fork return %d
", getpid(), pid);
sleep(1);
return 0;
}
运行结果:
[root@localhost linux]# ./a.out
Before: pid is 43676
After:pid is 43676, fork return 43677
After:pid is 43677, fork return 0
这里看到了三行输出,一行before,两行after。进程43676先打印before消息,然后它有打印after。另一个after 消息有43677打印的。注意到进程43677没有打印before,为什么呢?如下图所示
所以,fork之前父进程独立执行,fork之后,父子两个执行流分别执行。注意,fork之后,谁先执行完全由调度器决定。
②fork函数返回值
●子进程返回0,
●父进程返回的是子进程的pid。
③ 写时拷贝
通常,父子代码共享,父子再不写入时,数据也是共享的,当任意一方试图写入,便以写时拷贝的方式各自一份副本。具体见下图: