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

发表于:2020-6-15 10:37

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:佚名    来源:Java技术栈

#
java
#
Java
  在Java 中,这些短小的代码段一般会被放入一个class,然后保存到一个扩展名为 .java 的文件中;之后通过命令行或集成开发环境工具的编译,生成 .class文件并让这个 .class文件运行起来,得到我们想要的结果。
  例如,有一个简单的模仿游戏打开宝箱得到礼品的程序代码,参考如下:
  我们将其以文件形式保存到系统中,如图所示。
  已经保存到系统的 Java 的类文件
  这样,该文件中就包含了我们想要运行的一小段程序。当使用 Java 的命令或单击集成开发环境的run按钮时,程序就会运行起来,并且按照编写好的逻辑反馈相关信息。OpenBox 的运行结果如图所示。
  以上这些看似简单的操作过程,可以让我们更好地理解以下几个概念:程序、进程、线程。
  进程则是对某程序的运行过程。一般地,一份程序的一次运行能产生一个进程,进程是一个动态的概念。进程的运行是需要用到程序的内容的,更确切地说,进程的运行离不开程序,离不开程序中有特殊含义的文本。
  实际上,进程运行中有专门存放这些文本的区域,该区域称为代码文本区域。程序与进程是一对多的关系,即一个程序可以同时运行一个或多个进程。单击集成开发环境 的 run 按钮时,OpenBox.java 对应的一个进程就立刻产生了。
  理解好程序和进程的关系,就可以对线程加以描述和解释。线程是比进程更细小的一级划分, 线程可以利用进程所拥有的资源,并且能独立完成一项任务,如计算、输出显示信息等。在引入线程的操作系统中,通常是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位。
  进程与线程也是一对多的关系,即一个进程中至少有一个线程与之对应。如果一个进程中有多个线程同时存在,那么就是多线程的进程。上面的OpenBox.java 程序运行时,其在产生一个 进程的同时,也产生了一个单线程与之对应。也就是说,当运行 OpenBox.java程序时,该行为所产生的进程是一个单线程进程。
  程序、进程、线程的关系如图所示。
  程序、进程、线程的关系
  知识拓展:
  近年来,随着大数据的兴起,对于大数据的处理要求比传统的普通数据处理要求有了更高的 标准,Java 在大数据的处理方面也在不断地优化,特别是在开源社区中,许多开发贡献者提供了许 多大数据处理相关的组件和中间件。
  其中一个称为 quasar 的组件实现了 Java 的纤程。纤程是比线 程更小的一级划分,它所占用的系统资源更少,可以理解为更轻量级的一种特殊线程。一般地,从占用系统资源的大小方面来说,可以这样排序:进程 > 线程 > 纤程。

       本文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号