用户态多线程的3种实现方式
来源:互联网 发布:微软人工智能公开课 编辑:程序博客网 时间:2024/06/07 00:16
用户态的线程概念和内核态的线程概念不同。有三种模式,分别是:
(1).一对一
用户态一个线程对应内核态一个线程。用户态的线程并发执行,是真的并发执行。一个线程阻塞,不会影响其它线程。
缺点:
a:许多系统限制内核线程数量,这就直接限制了用户态的线程数量。
b:许多系统中,内核线程间的调度花销大,导致用户线程的执行效率下降。
(2)多对一
一个内核线程可以用于生成多个用户态线程。
优点:线程间切换花销小,高效的上下文切换,速度因此快了。用户态的线程数几乎是无限制的。
缺点:一个用户态线程阻塞,对应的内核线程也会阻塞,那么此内核态衍生出来的用户态线程组都阻塞了。
特征:因为是共用一个内核线程,随着用户态线程数的增加,线程的性能不会有明显的增加。
(3)多对多
像交换机一样,多个用户态线程通过一个中转节点,对应上内核态的多个线程。
优点:一个用户态线程阻塞,不会使得其它线程阻塞。线程数没限制。在多处理器系统上,性能有一定提升(但比不上一对一的)。
0 0
- 用户态多线程的3种实现方式
- JAVA多线程实现的3种方式
- 实现多线程安全的3种方式
- 用户态多线程实现的基本原理
- 用户态多线程实现的基本原理
- 多线程的实现方式
- 多线程的实现方式
- 多线程的实现方式
- 多线程的实现方式
- Java实现多线程的两种方式
- 实现多线程的两种方式
- iOS 多线程的几种实现方式
- JavaLearning:多线程的两种实现方式
- JAVA多线程实现的三种方式
- Java多线程实现的三种方式
- Java实现多线程的两种方式
- 多线程的两种实现方式
- JAVA多线程实现的三种方式
- android4.4 chrome使用mediacodec
- hdu 1005解题报告
- 多核心处理器知识与最大加速比计算方法-多处理器编译
- MVVM模式使用注意点
- 跟还是不跟?2014年网页设计趋势
- 用户态多线程的3种实现方式
- JDK5.0新特性:拆箱/装箱 特性 介绍
- 用具有差分AD输入的单片机测电阻值(电阻分压法)
- C# DataGridView控件 动态添加新行
- Java虚拟机内部构成浅析
- file控件选择上传文件确定后触发什么js事件
- 内部排序之一:插入排序和希尔排序的N中实现(不断优化,附完整源码)
- 中方首次向马航乘客家属通报情况
- Oracle性能调优