fork创建

  1. 进程的正式引入
    1)什么是进程
    动态过程而不是静态实物
    进程就是程序的一次运行过程,一个静态的可执行程序a.out 的一次运行过程(./a.out去运行到结束)就是一个进程。
    进程控制块PCB(process control block),内核中专门用来 管理一个进程的数据结构。
  2. 进程ID
    getpid、getppid、getuid、geteuid、getgid、getegid
  3. 进程调度原理
    操作系统同时运行多个进程
    宏观上的并行和微观上的串行
    实际上现代操作系统最小的调度单元是线程而不是进程
  4. fork创建子进程
    为什么要创建子进程
    每一次程序的运行都需要一个进程
    多进程实现宏观上的并行
  5. fork的内部原理
    1)进程的分裂生长模式。如果操作系统需要一个新进程来运行 一个程序,那么操作系统会用一个现有的进程来复制生成一个新 进程。老进程叫父进程,复制生成的新进程叫子进程。
    2)fork的演示
#include<stdio.h>
#include <sys/types.h>
#include <unistd.h>

int main(void)
{
    pid_t p1 = -1;
 
    p1 = fork();  // 返回两次
 
    if (p1 == 0)
    {
     	// 这里一定时子进程 
     	printf("子进程, pid = %d.\n", getpid());  // 返回本进程ID
    }
    
    if (p1 > 0)
    {
    	 // 这里一定时父进程
    	 printf("父进程, pid = %d.\n", getpid()); // 返回本进程ID
    	 printf("父进程, p1 = %d.\n", p1);  // 这里的p1和子进程的getpid的值是相等的
    }
    
    if (p1 < 0)
    {
   	  // fork 出错了 
    }
 
   // 在这里所做的操作
   // printf("hello world, pid = %d.\n", getpid());
   return 0; 
}

3 ) fork函数调用一次会返回2次,返回值等于0的就是子进程,而返回值大于0的就是父进程。
4 ) 典型的使用fork的方法:使用fork后然后用if判断返回值,并且返回值大于0时就是父进程,等于0时就是子进程。
5 ) fork的返回值在子进程中等于0,在父进程中等于本次fork创建的子进程的进程ID。

来源: 朱老师网络大课堂

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值