Java 线程模型

1. 基本概念

Progress 进程 是操作系统分配资源的基本单位。

Thread    线程 是 CPU 调度的基本单位, 比进程更轻量级的调度单位, 通过线程,可以把进程中的资源分配和资源调度分开,所有线程共享进程资源,又独立调度.

早期的操作系统中只有进程的概念,CPU 通过直接调用进程完成任务。任务的并发执行通过多进程实现。后来随着计算机应用的越来越庞大,进程所占据的资源也越来越多。CPU 为了实现任务的并发执行,切换进程所带来的的损耗也越来越大。为了解决上述问题,操作系统引入了更轻量级的线程。

  • 线程在进程下运行
  • 一个进程可以包含多个线程,至少包含一个线程
  • 同一进程下所有线程共享进程数据
  • 不同进程间数据不共享,不同线程间数据也不共享
  • 调度进程会带来更多的计算机资源消耗
  • 进程间不会互相影响,进程中线程挂掉会导致整个进程挂掉

现如今主流的操作系统都实现了线程的概念,java 代码中通过 Thread.start() 启动一个线程。该方法底层也是通过调用 JNI 方法实现的,即 java 创建线程是根据底层平台实现的

 

2. 常见的线程模型

内核线程模型 - Kernel Thread,即一对一线程模型 

用户线程模型- User Thread,    即1:N 模型

混合线程模型- 用户线程 + 轻量级进程混合实现, 即N:M 模型</

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值