多线程时Java程序运行的基础性机制,常用于高性能、高并发Java程序中。程序是存放在磁盘中的可执行文件,包括代码指令和数据,进程是操作系统管理应用程序的基本单元,是程序的一次启动执行,线程是编写并发程序的基础,是CPU调度的最小单元。
1. 进程
一个进程由程序段、数据段和进程控制块三部分组成
程序控制块(Program Control Block,PCB)由四部分组成
在进程内部,代码段和数据段有独立的地址空间,不同进程的地址空间是相互隔离的
2. 线程
线程是进程代码段的一次顺序执行流程,CPU调度的最小单元。各个线程之间共享进程的内存空间和系统资源
线程由三部分组成
在Java程序中,执行程序流程的单位是方法,栈内存的分配单位是栈帧,栈帧保存该方法中的局部变量、方法的返回地址和其他方法的相关信息
3. 进程和线程的区别
- 一个进程由一个或多个线程组成,一个进程至少有一个线程
- 线程是CPU调度的最小单位,进程是操作系统分配资源的最小单位
- 线程可以充分发挥CPU的计算性能,又弥补进程调度过于笨重的问题
- 进程之间相互独立,进程内部的各个线程并不完全独立,各个线程之间共享进程的方法区内存、堆内存和系统资源
- 线程上下文切换比进程上下文切换快得多
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/76756.html