0

0

什么是Java并发编程_进程与线程的区别及多核CPU执行原理

P粉602998670

P粉602998670

发布时间:2026-02-24 17:36:12

|

785人浏览过

|

来源于php中文网

原创

java中真正被cpu调度执行的是线程,进程仅作为资源容器;线程共享进程堆、文件句柄等资源,仅独占栈和程序计数器,故切换开销小但需处理竞态;单核下仅支持并发(时间片轮转),多核才支持并行(物理同时执行)。

什么是java并发编程_进程与线程的区别及多核cpu执行原理

进程和线程到底谁在“干活”?

Java里真正被CPU调度执行的是线程,不是进程。一个Java程序启动后是一个进程(比如 java -jar app.jar),但它默认至少有一个线程(main 线程);你用 new Thread()ExecutorService 开的,都是这个进程里的新线程。

关键区别在于资源:进程有独立的堆、文件句柄、JVM内存空间;线程只独占自己的栈和程序计数器,其余都共享进程资源——所以线程切换快、开销小,但共享也意味着必须处理竞态问题。

  • 别误以为“开了多个线程就等于开了多个JVM”,那是多个进程
  • jps -l 查看到的是进程;用 jstack <pid></pid> 才能看到里面所有线程状态
  • 线程崩溃(如未捕获异常)一般不会杀掉整个进程,但可能导致资源泄漏或状态不一致

单核CPU上能“并发”,但绝不可能“并行”

并发(concurrent)是宏观上“看起来一起跑”,本质是操作系统把CPU时间片(Windows约15ms,Linux更短)轮流分给不同线程;并行(parallel)是微观上“真正在同时跑”,必须有多核物理支持。

Java代码写得再“多线程”,在单核机器上永远只是并发——Thread.sleep(1)Object.wait()、I/O阻塞时,调度器就会切走CPU去跑别的线程。这不是Java的限制,是硬件决定的。

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

Paraflow
Paraflow

AI产品设计智能体

下载
  • Runtime.getRuntime().availableProcessors() 返回的是逻辑核数,不是“保证可用”的并发能力
  • 不要靠“线程数 = CPU核数”硬配线程池,还要看任务类型:CPU密集型用 N,IO密集型常用 2N 甚至更高
  • VisualVMJFR 观察 Thread State,如果大量线程长期处于 WAITINGBLOCKED,说明不是CPU瓶颈,而是锁或IO拖慢了

synchronized 和 wait/notify 的坑,90%人栽在唤醒逻辑上

synchronized 加锁后调 wait(),不是“暂停自己等信号”,而是“释放锁 + 进入等待队列”;notify() 不保证唤醒哪个线程,notifyAll() 才是安全选择——尤其在多个条件共用一把锁时。

典型翻车场景:三个线程轮着打印数字,有人写 if (count % 3 != index) wait(),但被唤醒后没再检查条件,直接往下执行,导致跳号或重复打印。

  • 必须用 while 而不是 if 包裹 wait(),防止虚假唤醒(spurious wakeup)
  • wait() 必须在 synchronized 块内调用,否则抛 IllegalMonitorStateException
  • sleep() 不释放锁,wait() 会释放——这是二者最根本的行为差异,别混用

多核CPU下,并行≠自动高效

有了8核,不代表8个线程就能跑满800% CPU。Java线程映射到OS线程,最终由内核调度;如果线程频繁争抢同一把锁、或反复GC导致Stop-The-World,再多核也白搭。

真实瓶颈常藏在看不见的地方:HashMap扩容时的锁竞争、日志框架的同步刷盘、甚至JIT编译过程中的去优化(deoptimization)。

  • -XX:+PrintGCDetails 看GC是否拖累吞吐;用 -XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly(需hsdis)查热点方法是否被内联
  • 避免在高并发路径上用 String.substring()(老版本JDK中可能共享底层数组引发内存泄漏)
  • 线程局部变量优先用 ThreadLocal,但记得手动 remove(),尤其在线程池场景下,否则可能引发内存泄漏
实际写并发代码时,最难的往往不是语法,而是判断“这里到底要不要锁”“该用什么粒度锁”“唤醒之后条件还成不成立”。这些没法靠背API解决,得结合堆栈、火焰图、GC日志一点点对齐预期和现实。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

850

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

829

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

199

2023.11.20

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

103

2023.09.25

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

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

422

2023.07.18

堆和栈区别
堆和栈区别

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

595

2023.08.10

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

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

422

2023.07.18

堆和栈区别
堆和栈区别

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

595

2023.08.10

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

热门下载

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

精品课程

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

共23课时 | 3.9万人学习

C# 教程
C# 教程

共94课时 | 10.1万人学习

Java 教程
Java 教程

共578课时 | 71.5万人学习

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

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