Java高并发程序-Chapter2 Java并行程序基础 (第四讲)进程和线程


1. 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。

用稍微专业点的术语说,线程就是轻量级进程,是程序执行的最小单位。使用多线程而不是用多进程去进行并发程序的设计,是因为线程间的切换和调度的成本远远小于进程。

2. 线程状态


NEW状态表示刚刚创建的线程,这种线程还没开始执行。等到线程的Start方法调用时才表示线程开始执行。
当线程执行时,处于RUNNABLE状态,表示线程所需的一切资源都已经准备好了。
如果线程在执行过程中遇到了synchronized同步块,就会进入BLOCKED阻塞状态,这时线程就会暂停执行,直到获得请求的锁。

WAITING和TIMED_WAITING都表示等待状态,它们的区别是WAITING会进入一个无时间限制的等待, TIMED WAITING会进行一个有时限的等待。


那等待的线程究竟在等什么呢?


一般来说, WAITING的线程正是在等待一些特殊的事件。比如,通过 wait方法等待的线程在等待 notify方法,而通过 join方法等待的线程则会等待目标线程的终止。
一旦等到了期望的事件,线程就会再次执行,进入RUNNABLE状态。
当线程执行完毕后,则进入TERMINATED状态,表示结束


注意: 从NEW状态出发后,线程不能再回到NEW状态,同理,处于TERMINATED的线程也不能再回到RUNNABLE状态


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值