0

0

在Java中什么是线程模型_Java并发执行基础概念解析

P粉602998670

P粉602998670

发布时间:2026-01-04 13:36:08

|

897人浏览过

|

来源于php中文网

原创

java采用1:1内核线程模型,即每个java线程对应一个操作系统内核线程,由jvm通过lwp委托内核调度;该模型支持真正并行、避免i/o阻塞全局化,但带来栈空间占用大和创建开销高等代价。

在java中什么是线程模型_java并发执行基础概念解析

线程模型指Java如何在底层映射和管理操作系统线程,它决定了线程的调度方式、资源开销与阻塞行为。Java采用的是**1:1内核线程模型**——每个Java线程对应一个操作系统内核线程(Kernel-Level Thread),由JVM通过轻量级进程(LWP)直接委托给内核调度。 这个模型不是Java语言规范强制规定的,而是HotSpot JVM在主流平台(Linux/Windows/macOS)上的实际实现,也是你写 new Thread(...).start() 时真正发生的事。

为什么Java用1:1模型而不是用户线程(1:N)?

早期JVM曾尝试过用户线程(如Green Threads),但已被淘汰。原因很实在:

  • 内核线程能天然支持真正的并行:多核CPU上多个Java线程可同时运行,不依赖JVM自己做时间片轮转
  • 系统调用不会导致整个进程挂起:比如一个线程执行FileInputStream.read()被I/O阻塞,其他线程照常运行
  • 现代操作系统对线程调度已非常成熟,JVM无需重复造轮子

代价也很明确:每个Java线程至少占用1MB空间(可通过-Xss调整),且线程创建/销毁需系统调用,开销比纯用户态线程大。

“线程模型”和“线程创建方式”是两回事

新手容易混淆这两个概念。你写RunnableCallable或继承Thread,只是定义了任务逻辑和启动入口;最终执行时,JVM仍会为每个start()调用分配一个内核线程——无论你用哪种API。

换句话说:

Mokker AI
Mokker AI

AI产品图添加背景

下载

立即学习Java免费学习笔记(深入)”;

  • new Thread(runnable).start() → 创建1个内核线程
  • executor.submit(callable)(用ThreadPoolExecutor)→ 复用已有内核线程,不新增
  • ForkJoinPool.commonPool().submit(...) → 仍是内核线程,只是共享ForkJoinWorkerThread实例

模型没变,变的是你是否复用线程。

常见误解:Thread.sleep() / wait() 会释放内核线程吗?

不会。它们只让当前线程进入TIMED_WAITINGWAITING状态,但对应的内核线程仍然存在,只是不参与CPU调度。只有线程执行结束(run()返回)或被中断且退出,内核线程才会被操作系统回收。

这也是为什么无限制创建线程+大量sleep()仍会导致OOM:线程对象+栈内存+内核资源三重堆积。

真正需要警惕的,从来不是“怎么创建线程”,而是“有没有让线程活太久、开太多、等太长”。模型本身很透明,麻烦都在使用习惯里。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

723

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

95

2025.12.01

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1357

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1159

2023.07.27

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号