Java多线程 一、进程和线程

2021/12/7 7:16:40

本文主要是介绍Java多线程 一、进程和线程,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

一、什么是进程与线程

进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。程序是指令、数据及其组织形式的描述,进程是程序的实体。

简单来说就是我们运行一个程序时系统就会创建一个进程,并且对这个进程进行资源的分配。

我们打开电脑的任务管理器,可以清楚的看到当前电脑上有那些进程具体分配了那些资源

在这里插入图片描述
线程(thread)是操作系统能够进行运算调度的最小单位。它被包含进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。
在这里插入图片描述

二、进程和线程的关系

通过上面进程和线程的定义,我们不难看出
1.进程是系统进行资源分配和调度的基本单位,线程是进行运算调度的最小单位,线程是再进程里面的,它可以是多个,可以并行执行不同的任务
2.进程在被创建的时候所分配的资源(代码和常量、全局变量和静态变量、堆存储等)是被所有线程共享的,但是每个线程拥有自己的栈段,栈段又叫运行时段,用来存放所有局部变量和临时变量。

简单来说二者关系,进程就是一个再创建、撤销和切换中时空开销较大的资源拥有者,所以导致系统并发的成本较高,限制了并发,因此人们提出了线程,使其作为运算调度分派的最小单位解决并发问题。

三、进程和线程的区别

1.调度

在同一进程中,线程的切换不会引起进程的切换,在 由一个进程中的线程切换到另一个进程中的线程时,将会引起进程的切换。

2.并发性

在引入线程的操作系统中,不仅进程之间可以并发执行,而且在一个进程中的多个线程之间,亦可并发执行

3.拥有资源

进程是拥有资源的一个独立单位,它可以拥有自己的资源,而线程自己不拥有系统资源(也有一点必 不可少的资源),只是可以使用进程的资源

4.系统开销

进程开销大,线程开销小



这篇关于Java多线程 一、进程和线程的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程