Java多线程 一、进程和线程

一、什么是进程与线程

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

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

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

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

二、进程和线程的关系

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

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

三、进程和线程的区别

1.调度

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

2.并发性

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

3.拥有资源

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

4.系统开销

进程开销大,线程开销小

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值