进程、线程、纤程的区别,有几个人知道?

开发 后端
在Java 中,这些短小的代码段一般会被放入一个class,然后保存到一个扩展名为 .java 的文件中;之后通过命令行或集成开发环境工具的编译,生成 .class文件并让这个 .class文件运行起来,得到我们想要的结果。

在Java 中,这些短小的代码段一般会被放入一个class,然后保存到一个扩展名为 .java 的文件中;之后通过命令行或集成开发环境工具的编译,生成 .class文件并让这个 .class文件运行起来,得到我们想要的结果。

例如,有一个简单的模仿游戏打开宝箱得到礼品的程序代码,参考如下:

我们将其以文件形式保存到系统中,如图所示。

 已经保存到系统的 Java 的类文件

这样,该文件中就包含了我们想要运行的一小段程序。当使用 Java 的命令或单击集成开发环境的run按钮时,程序就会运行起来,并且按照编写好的逻辑反馈相关信息。OpenBox 的运行结果如图所示。

以上这些看似简单的操作过程,可以让我们更好地理解以下几个概念:程序、进程、线程。

进程则是对某程序的运行过程。一般地,一份程序的一次运行能产生一个进程,进程是一个动态的概念。进程的运行是需要用到程序的内容的,更确切地说,进程的运行离不开程序,离不开程序中有特殊含义的文本。

实际上,进程运行中有专门存放这些文本的区域,该区域称为代码文本区域。程序与进程是一对多的关系,即一个程序可以同时运行一个或多个进程。单击集成开发环境 的 run 按钮时,OpenBox.java 对应的一个进程就立刻产生了。

理解好程序和进程的关系,就可以对线程加以描述和解释。线程是比进程更细小的一级划分, 线程可以利用进程所拥有的资源,并且能独立完成一项任务,如计算、输出显示信息等。在引入线程的操作系统中,通常是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位。

进程与线程也是一对多的关系,即一个进程中至少有一个线程与之对应。如果一个进程中有多个线程同时存在,那么就是多线程的进程。上面的OpenBox.java 程序运行时,其在产生一个 进程的同时,也产生了一个单线程与之对应。也就是说,当运行 OpenBox.java程序时,该行为所产生的进程是一个单线程进程。

程序、进程、线程的关系如图所示。

程序、进程、线程的关系

知识拓展:

近年来,随着大数据的兴起,对于大数据的处理要求比传统的普通数据处理要求有了更高的 标准,Java 在大数据的处理方面也在不断地优化,特别是在开源社区中,许多开发贡献者提供了许 多大数据处理相关的组件和中间件。

其中一个称为 quasar 的组件实现了 Java 的纤程。纤程是比线 程更小的一级划分,它所占用的系统资源更少,可以理解为更轻量级的一种特殊线程。一般地,从占用系统资源的大小方面来说,可以这样排序:进程 > 线程 > 纤程。

本文授权转载自《Java 多线程与大数据处理实战》一书,更多请参考这本书。 

 

责任编辑:庞桂玉 来源: Java技术栈
相关推荐

2010-11-08 13:04:36

SQL SERVER线

2023-11-17 11:36:59

协程纤程操作系统

2023-10-12 09:46:00

并发模型线程

2018-12-11 14:40:53

HashMapHashtableJava

2021-09-08 10:54:55

开源Linus创始人

2010-07-08 16:00:51

SQL Server线

2010-11-08 13:15:13

SQL SERVER线

2010-07-20 10:34:51

SQL Server线

2023-10-11 07:39:58

Java虚拟线程

2010-07-07 14:57:25

SQL Server线

2023-11-29 08:02:16

线程进程

2020-03-23 10:08:56

5G网络技术

2010-06-30 08:13:18

SQL Server数

2020-11-29 17:03:08

进程线程协程

2023-12-13 09:56:13

​多进程多线程协程

2012-10-31 10:43:27

职涯规划能力培养开发

2012-10-31 10:42:34

培养挑战开发

2022-02-08 07:02:32

进程线程操作系统

2019-08-29 09:10:45

MySQLSQL数据库

2020-04-07 11:10:30

Python数据线程
点赞
收藏

51CTO技术栈公众号