Linux——多线程中执行fork

前言

  1. 多线程中某个线程调用 fork(),子进程会有和父进程相同数量的线程吗?
  2. 父进程被加锁的互斥锁 fork 后在子进程中是否已经加锁?

先来解决第一个问题:
创建一个线程,有两条路径,一条是主线程,一条是子线程,在主线程加入fork();
在这里插入图片描述
fork之后,主进程有两个线程,我们来看看子进程究竟有几个线程

注意:不管在哪个线程打印pid,pid的值都是整个进程的id号
在这里插入图片描述

于是:我们发现父进程的pid是5831,子进程的pid是5833,父进程的id在主线程和子线程中均被输出,子进程的id只有在主进程中输出

创建一个线程,有两条路径,一条是主线程,一条是子线程,在子线程执行fork();
执行结果如下:
在这里插入图片描述

父进程的id号为5895,子进程的id号为5897
子进程的id号只在子线程打印,父进程的id号在主线程和子线程都打印

总结

  • 其实,不管父进程有多少条执行路径,子进程只有一条执行路径;
  • 既然父进程有多条执行路径,那么fork执行的就是的fork所在的那一条执行路径中。

fork是复制进程,但是他只会复制进程中的一条执行路径,这是因为设计问题,在设计多线程程序时,最后发现,如果全都复制,程序会非常复杂,难以控制。

对于第二个问题的解答:
父进程中创建了锁,使用它,再fork,其实这个锁是属于父进程的资源,所以子进程也会复制这把锁,就会产生两把锁,锁的状态取决于fork的那一刻父进程锁的状态,子进程会同步于父进程的锁状态。因为程序的并发运行,这个锁的状态难以确定。
我们只能在没有任何控制的时候再进行fork,

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值