Java中进程是操作系统分配资源的单位,线程是CPU调度执行的单位;进程独占内存、PID和运行环境,线程共享进程资源但私有栈和PC,创建成本低、通信高效,且生命周期依附于进程。

Java中线程和进程的区别,核心在于“谁管资源、谁被调度”。进程是操作系统分配资源的单位,线程是CPU实际执行的单位——一句话就能抓住本质。
进程是独立运行的“程序实例”
每次你敲 java Main 启动一个Java应用,就创建了一个JVM进程。这个进程拥有:
- 自己独占的内存空间(堆、方法区、系统文件句柄等)
- 独立的进程ID(PID),由操作系统管理
- 完整的运行环境,包括JVM虚拟机实例
多个JVM进程之间互不共享内存,通信必须走进程间通信机制(如Socket、管道、文件),开销大、编程复杂。
线程是进程内部的“执行路径”
同一个JVM进程中,可以同时存在多个线程,比如主线程(执行main方法)、垃圾回收线程、用户自定义线程等。它们的特点是:
立即学习“Java免费学习笔记(深入)”;
- 共享进程的堆内存、方法区、已加载的类、打开的文件等资源
- 各自拥有私有栈空间、程序计数器、线程局部变量(ThreadLocal)
- 由JVM和操作系统协同调度,切换成本远低于进程
例如:你在main方法里启动两个新线程处理网络请求和写日志,它们能直接读写同一个HashMap(注意并发安全),但各自的局部变量互不影响。
关键区别落在四点上
资源归属:进程独占资源;线程只“借住”,共享所属进程的一切(除私有栈和PC寄存器)。
创建销毁成本:新建一个进程要申请内存、复制页表、初始化PCB,耗时毫秒级;新建一个线程只需分配栈(默认1MB左右)和登记线程对象,微秒级完成。
通信方式:进程间通信(IPC)需系统介入(如信号量、共享内存、消息队列);线程间通信靠共享内存+同步机制(synchronized、Lock、volatile)即可,更直接高效。
生命周期依赖:进程退出,其所有线程立即终止;线程结束,进程仍可继续运行(只要还有其他活跃线程)。
Java里最直观的例子
写一个HelloWorld程序:
- 运行 java HelloWorld → 启动1个JVM进程
- JVM自动创建主线程,执行main() → 这是第1个线程
- 在main里 new Thread(() -> System.out.println("Hi")).start() → 新增第2个线程
- 两个线程共享同一个System.out、同一块堆内存,但各自有独立的调用栈
没有进程,线程无法存在;没有线程,进程就只是静止的代码——Java的并发能力,正是建立在这层清晰的分工之上。










