线程模型

实现线程主要有三种方式:1)使用内核线程实现(1:1),2)使用用户线程实现(1:N),3)使用用户线程加轻量级进程混合实现(N:M)

1、使用内核实现

内核线程就是直接由操作系统内核支持的线程,由操作系统对线程进行分配、调度。程序通过内核线程的高级接口-轻量级进程(Light Weight Proccess,LWP,我们通常意义上的线程)使用内核线程。由于每个轻量级进程都由一个内核线程支持,因此只有先支持内核线程才能有轻量级进程。轻量级进程和内核线程的关系是1:1对应关系。

优点:每个轻量级进程都成为一个独立的调度单元,其中某一个被阻塞了也不会影响整个进程的工作。

缺点:由于是基于内核线程实现的,所以各种线程操作都需要进行系统调用。而系统调用的代价相对较高,需要在用户态和内核态之间来回切换。其次,每个轻量级进程都需要有一个内核线程的支持,因此轻量级进程要消耗一定的内核资源(如内核线程的栈空间),因此一个系统支持轻量级里程的数量是有限的。

 

2、用户线程实现

狭义止的用户线程指的是完全建立在用户空间的线程库上,系统内核不能感知到用户线程的存在及如何实现。线程的所有操作完全在用户态中完成,如果实现得当,这种线程不需要切换到内核态,因此操作可以是非常快速且低消耗的,支持规模更大的线程数量。

优点:不需要内核的支持

缺点:线程的所有操作都是由用户考虑的,诸如“阻塞如何处理”,“多处理器系统中如何将线程映射到其他处理器上”等问题解决起来异常困难,甚至不可能实现。所以一般的应用程序不使用。

 

3、混合实现

将内核线程与用户线程一起使用的实现方式,被称为N:M实现。

用户线程建立在用户空间中,操作系统支持的轻量级进程则作为用户线程和内核线程之间的桥梁,这样可以使用内核提供的线程调度功能及处理器映射,并且用户线程的系统调用通过轻量级进程完成。这种混合模式中,用户线程与轻量级进程的数量比是不定的,是N:M关系。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值