操作系统学习记录
死锁
1.何为死锁
死锁是指多个进程争夺资源而处于的僵持状态
2.产生原因
系统资源不足。竞争资源和进程间推进顺序非法
3.解决死锁的四种方法
预防 避免 解除 检测
4.产生死锁的条件
1.互斥条件:一个资源每次只能被一个进程使用
2.不可剥夺条件:进程已获得资源,在未使用完之前,不能被其他进程强行剥夺,只能主动释放
3.请求和保持条件:进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源已被其他进程占有,此时请求进程被阻塞,但对自己已获得的资源保持不放。
4.循环等待条件:即进程集合{p0,p1,p2,p3……pn};p0正在等待p1占用的资源,p1正在等待p2占用的资源,pn正在等待p0占用的资源。
4.预防死锁具体方法
1.当一个占有资源进程请求新任务时,如果系统不能满足,进程应该释放当前所有的资源才可以重新申请。
2.如果系统有足够的资源,系统一次性把资源分配给进程需要的资源
3.按照顺序严格的分配进程顺序,按照类型排序序号排序,进程对资源请求必须按照序号递增的次序提出
进程和线程
1.进程:一个程序即一个线程,即一个程序运行时的实例。分配系统资源的最小单位
**线程:**系统分配处理器时间资源的基本单元,或者说进程之内独立执行的一个单元执行流。进程——资源分配的最小单位,线程——程序执行的最小单位。
2.简单来记:
-
简而言之,一个程序至少有一个进程,一个进程至少有一个线程.
-
线程的划分尺度小于进程,使得多线程程序的并发性高。
-
另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。
-
线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
-
从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。
3 优缺点:
线程开销小,但不利于资源的管理和保护;进程与之相反。