进程间切换的步骤:
1,保存程序计数其以及其他寄存器。
2, 更新当前处于“运行态”的进程的进程控制块,把进程状态改为相应状态,
更新其他相关域
3, 把被切换进程的进程控制块移到相关状态的队列
4, 选择另外一个进程开始执行,把该进程进程控制块的状态改为“运行态”
5, 恢复被选择进程的处理器在最近一次被切换出运行态时的上下文,比如载入
程序计数器以及其他处理器的值
进程间切换伴随着两次模式切换(用户--内核,内核--用户)。
(同一进程内)线程间切换的步骤:
线程分两种,用户级线程和内核级线程
在用户级线程中,有关线程管理的所有工作都由应用程序完成,内核没有意识到
线程的存在。
(同一进程内)用户级线程间切换时,只需要保存用户寄存器的内容,程序计数
器,栈指针,不需要模式切换。
缺点:
1, 在进程的某个线程执行系统调用时,不仅该线程被阻塞,该线程所在进程的
所有线程都被阻塞
2, 无法利用多处理器
在内核级线程中,有关线程的管理工作都是由内核完成的,应用程序部分没有线
程管理的权限,只有一个接口(API)
(同一进程内)内核级线程间切换时,除了保存上下文,还要进行模式切换。
优点:
1, 可以利用多处理器
2, 线程阻塞不会导致进程阻塞
相关文章
- 操作系统OS,Python - 多进程(multiprocessing)、多线程(multithreading)
- 【redis】redis 手动切换主从
- 关于asp.net和iis的进程/线程问题,假如网站有1000个人访问,会产生多少个进程/线程啊
- wifi分析仪怎么看哪个信道好_一定得学的切换WiFi信道技巧,让你的网速如飞!...
- pytorch 换版本_Pytorch 模型版本切换
- Python中的进程池与线程池
- python 之 并发编程(进程池与线程池、同步异步阻塞非阻塞、线程queue)
- py 并发编程(线程、进程、协程)
- 第十章:Python高级编程-多线程、多进程和线程池编程
- Python笔记_第四篇_高阶编程_进程、线程、协程_3.进程vs线程