• 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. 逐步抢占涉及死锁的进程占有的资源,直到死锁解除
  • 相关阅读:
    Java---数据库---MyBatisPlus
    MOSFET 选型
    ExpressGridPack 23 Crack
    【视觉检测】电源线圈上的导线弯直与否视觉检测系统软硬件方案
    Latex 安装与配置
    【JAVA】SpringMVC(下)—— SSM整合&异常处理器
    Spring Boot自动装配原理超详细解析
    uni-app:允许字符间能自动换行(英文字符、数字等)
    requests库进行爬虫ip请求时遇到的错误解决方法
    使用 Vue3 构建 Web Components
  • 原文地址:https://blog.csdn.net/sqjddb/article/details/126269665