父子进程代码段共享,子进程还会继承父进程的环境变量、文件描述符表。父子进程有独立的数据段、堆、栈,这些区域的数据发生写时拷贝前映射的是同一块物理内存。父子进程的PID、PPID、fork()的返回值不同
共享区?
共享的内容:
进程的多个线程共享代码段、数据段、堆区。
以及一些具体的内容比如:
文件描述符表
每种信号的处理方式(SIG_ IGN、SIG_ DFL或者自定义的信号处理函数)
当前工作目录
用户id和组id
线程独有的内容:
线程ID
栈(划分进程的栈区)
错误返回码errno
信号屏蔽字
调度优先级
一组寄存器
进程的某个线程如果拿到其他线程栈区数据的地址也可以访问
什么是死锁?
死锁指一组进程中各个进程均占有并且不释放资源,但因互相申请被其他进程占有并且不释放的资源而处于的一种永久等待的状态。
死锁的四个必要条件?
互斥条件:一个资源每次只能被一个执行流使用
请求与保持条件:一个执行流因请求资源而阻塞时,对已获得的资源保持不释放
不剥夺条件:一个执行流已获得的资源不能被强行剥夺
循环等待条件:若干执行流之间形成一种头尾相接的循环等待资源的关系
如何解决死锁?
悲观一些的方法:预防和避免死锁
乐观一些的方法:死锁发生后解除或者使用检测死锁的算法
预方死锁:
破坏四个必要条件:
破坏互斥条件:使资源可以被同时访问,很多资源往往是不能同时被访问的 ,所以这种方法使用场景不多。
破坏不剥夺条件:采用剥夺式调度算法,会导致资源利用率下降。
破坏请求与保持条件:使用静态分配策略,在执行流执行前分配给它所需的全部资源,但会使资源利用率很低。
破坏循环等待条件:使用层次分配策略,给资源分层,一个执行流申请到某个资源后,只能申请层次更高的资源,释放资源时必须先释放高层次的资源。
使用一些避免死锁的算法,比如银行家算法,试探性地给执行流分配资源,然后通过安全性算法判断分配后系统是否处于安全状态,若不安全则试探分配作废。
解除死锁: