Linux进程/线程几个经典问题

fork()后发生了什么

  1. 系统为子进程开辟新的用户空间,创建进程控制块对应的数据结构task_struct,为子进程分配一个PID。
  2. 设置子进程地址空间到物理内存的映射,父子进程代码段映射的是同一块物理内存,数据采用写时拷贝的方式,可以节省内存空间。
  3. 子进程的task_struct加入到内核的管理链表中,fork()返回。

父子进程的内容有何异同

父子进程代码段共享,子进程还会继承父进程的环境变量、文件描述符表。父子进程有独立的数据段、堆、栈,这些区域的数据发生写时拷贝前映射的是同一块物理内存。父子进程的PID、PPID、fork()的返回值不同

共享区?

线程独占和共享的资源有哪些

共享的内容:
进程的多个线程共享代码段、数据段、堆区。
以及一些具体的内容比如:
文件描述符表
每种信号的处理方式(SIG_ IGN、SIG_ DFL或者自定义的信号处理函数)
当前工作目录
用户id和组id

好文推荐

线程独有的内容:
线程ID
栈(划分进程的栈区)
错误返回码errno
信号屏蔽字
调度优先级
一组寄存器

进程的某个线程如果拿到其他线程栈区数据的地址也可以访问

死锁相关问题

什么是死锁?
死锁指一组进程中各个进程均占有并且不释放资源,但因互相申请被其他进程占有并且不释放的资源而处于的一种永久等待的状态。

死锁的四个必要条件?
互斥条件:一个资源每次只能被一个执行流使用
请求与保持条件:一个执行流因请求资源而阻塞时,对已获得的资源保持不释放
不剥夺条件:一个执行流已获得的资源不能被强行剥夺
循环等待条件:若干执行流之间形成一种头尾相接的循环等待资源的关系

如何解决死锁?
悲观一些的方法:预防和避免死锁
乐观一些的方法:死锁发生后解除或者使用检测死锁的算法

预方死锁:

  1. 破坏四个必要条件:
    破坏互斥条件:使资源可以被同时访问,很多资源往往是不能同时被访问的 ,所以这种方法使用场景不多。
    破坏不剥夺条件:采用剥夺式调度算法,会导致资源利用率下降。
    破坏请求与保持条件:使用静态分配策略,在执行流执行前分配给它所需的全部资源,但会使资源利用率很低。
    破坏循环等待条件:使用层次分配策略,给资源分层,一个执行流申请到某个资源后,只能申请层次更高的资源,释放资源时必须先释放高层次的资源。

  2. 使用一些避免死锁的算法,比如银行家算法,试探性地给执行流分配资源,然后通过安全性算法判断分配后系统是否处于安全状态,若不安全则试探分配作废。

解除死锁:

  1. 重启操作系统,损失较大
  2. 关闭涉及死锁的进程,可以全部关闭或者逐步关闭直到破除死锁
  3. 逐步抢占涉及死锁的进程占有的资源,直到死锁解除
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

江南无故人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值