fork()函数通过系统调用并创建
一个与原来进程几乎完全相同的进程
此进程叫做子进程
,两个进程做一样的事
但初始参数或者传入的变量不同,两个
进程便可以做不同的事
fork的返回值
在父进程中,fork返回新创建子进程的进程ID
在子进程中,fork返回0
如果出现错误,fork返回一个负值
调用fork之后
父子进程同时执行fork之后的代码
之前的代码由父进程执行
每个进程都有唯一的PID
PCB:进程控制块
通过task_struct结构体实现
父进程返回子进程PID
子进程PID = 父进程 + 1
获取父子进程PID代码
#include
#include
int main()
{
pid_t id = fork();
if (id < 0)
{
printf("创建子进程失败\n");
return 0;
}
else if(id == 0)
{
printf("我是子进程:pid: %d\n", getpid());
}
else
{
printf("我是父进程:pid: %d\n", getpid());
}
return 0;
}
两个判断语句都执行了
由此判断确实执行了两次
pid_t 是short类型
用来接收进程pid
main函数里有多个fork,父进程多次fork后
打印结果并不不唯一。因为cpu执行代码时
父子进程是同时运行的,谁抢到cpu谁就先
运行,与系统调度有关
✨✨✨✨✨✨✨✨
本篇博客完,感谢阅读
如有错误之处可评论指出
博主会耐心听取每条意见
✨✨✨✨✨✨✨✨