Java基础之线程与进程

一.线程

1. 概念:
线程是程序执行中一个单一的顺序控制流程,是程序执行流的最小单元,是处理器调度和分派的基本单位。比进程更小的独立运行的基本单位。线程也被称为轻量级进程。
2. 特点:
(1)轻型实体
线程中的实体基本上不拥有系统资源,只是有一点必不可少的、能保证独立运行的资源。
线程的实体包括程序、数据和TCB。线程是动态概念,它的动态特性由线程控制块TCB(Thread Control Block)描述。
(2)独立调度和分派的基本单位
在多线程OS中,线程是能独立运行的基本单位,因而也是独立调度和分派的基本单位。由于线程很“轻”,故线程的切换非常迅速且开销小(在同一进程中的)。
(3)可并发执行
在一个进程中的多个线程之间,可以并发执行,甚至允许在一个进程中所有线程都能并发执行;同样,不同进程中的线程也能并发执行,充分利用和发挥了处理机与外围设备并行工作的能力。
(4)共享进程资源
在同一进程中的各个线程,都可以共享该进程所拥有的资源,所有线程都具有相同的地址空间(进程的地址空间)。线程不仅可以访问该地址空间的每一个虚地址,还可以访问进程所拥有的已打开文件、定时器、信号量机构等。由于同一个进程内的线程共享内存和文件,所以线程之间互相通信不必调用内核。

二.进程 **

1. 概念:
是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程,是操作系统进行资源分配和调度的一个独立单位,是应用程序运行的载体。程序控制块包含进程的描述信息和控制信息,是进程存在的唯一标志。
2. 特点:
(1)动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生,动态消亡的。
(2)并发性:任何进程都可以同其他进行一起并发执行。
(3)独立性:进程是系统进行资源分配和调度的一个独立单位。
(4)结构性:进程由程序,数据和进程控制块三部分组成。

三.线程与进程的区别

1.线程是程序执行的最小单位,而进程是操作系统分配资源的最小单位。
2.一个进程由一个或多个线程组成,线程是一个进程中代码的不同执行路线。
3.进程之间相互独立,但同一进程下的各个线程之间共享程序的内存空间(包括代码段,数据集,堆等)及一些进程级的资源(如打开文件和信号等),某进程内的线程在其他进程不可见。
4.调度和切换:线程上下文切换比进程上下文切换要快得多。

四.线程与进程的关系

1.线程是进程的一部分。
2.一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
3.线程和进程关系示意图:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值