Java 复习 —— 一张图读懂多线程

1、带着疑问看图

1)竞争对象的锁和竞争CPU资源以及竞争被唤醒

2)何种情况下获取到了锁,何种情况下会释放锁

2、还是那张图

3、详细图解

1)Thread t = new Thread(),初始化一个线程,实际上就是一个普通对象,此时他的状态为New

2)t.start(); 线程处于就绪状态(可运行状态),也就是随时等待着运行, 不要小看这个start,这个start决定了他是否是一个真正的线程实例,因为start为其准备了线程环境,你若只是普通调用run方法,那么这就是一个普通的方法。处在这个时候的线程,都会去竞争CPU资源,所以谁被竞争到了CPU资源,也就是被调度Scheduler,那么他就可以从可运行状态到真正运行状态。

3)当线程获取到了CPU资源时,线程就从可运行状态到真正运行状态,也就是Running,不用怀疑,他现在正在运行。

4)如果这个线程正在等待客户输入学习,也就是IO异常,等各种阻塞事件,也有可能是自己调用了sleep等阻塞事件,线程就会从运行状态转为阻塞状态,这个状态是不会发生任何事情的!

5)一旦阻塞事件被清除,比如用户已经输入完成,IO流已经关闭,sleep也已经超时等,线程从阻塞状态变为就绪状态,又一次回到了可运行状态,随时与别的线程竞争资源,等待运行!

6)处于运行状态的线程可能会在运行当中遇到了同步方法或同步块,也就是synchronized标记的方法或块,这个时候该线程获到了对象的锁,其他线程就无法进入该同步方法,那么这些无法执行的线程怎么办呢?他们就都阻塞在这里,等待锁的释放,从新去竞争锁资源,因为只有拥有锁的线程才有资格继续往下运行,那么这里这些线程就阻塞在锁池(Lock Pool)。

7)一旦被阻塞在锁池的线程竞争到了锁(之前的线程运行完了或之前的线程在内部跑出来异常,或者调用了wait等,都会释放线程的锁),那么这个线程就会从阻塞状态转为就绪状态,不要以为这个线程会立刻执行,这是不可能的,你要想到线程执行都是要获取到CPU资源的,如果没有操作系统的调度,他们都没有资格运行!

8)处于运行状态的线程可能会在运行当中进入了同步方法或同步块,这个时候他拥有了对象的锁,至高无上,可是由于当前环境可能导致他没必要继续执行,所以他会自己让出锁资源让别的线程也有机会继续执行,所以这个线程可能在synchronized内部调用所对象的wait方法,一旦调用,当前线程让出锁资源,同时自己进入等待池(wait pool)中,直到被别的线程唤醒!如果没有被唤醒就一直会处在等待池当中,受到线程的阻塞,所以这个时候他们一心想要的是被唤醒,因为只有唤醒才有可能继续运行!

9)一旦被阻塞在等待池的线程被唤醒(可能是某个synchronized的线程调用了notify或notifyAll,也可能是外部调用interrupt导致内部抛出异常,也会获取到锁),那么这个线程就会从等待池转为锁池当中,继续阻塞,所以不要以为线程被唤醒就会继续运行,这是不可能的,他们同样需要竞争锁资源。

10)线程运行过程中抛出异常,或者线程实在运行完了,那么线程就结束了,也就是消亡期。运行完了是不可以继续start的,必须从新new 一个线程才能start。那么将是有一个生命周期。

时间: 2024-11-05 13:38:47

Java 复习 —— 一张图读懂多线程的相关文章

比传统事务快10倍?一张图读懂阿里云全局事务服务GTS

摘要: 近日,阿里云全局事务服务GTS正式上线,为微服务架构中的分布式事务提供一站式解决方案.GTS有哪些功能,相比传统事务的优势在哪呢?我们通过一张图读懂GTS. 近日,阿里云全局事务服务GTS正式上线,为微服务架构中的分布式事务提供一站式解决方案.GTS的原理是将分布式事务与具体业务分离,在平台层面开发通用的事务中间件GTS,由事务中间件协调各服务的调用一致性,负责分布式事务的生命周期管理.服务调用失败的自动回滚,性能比XA协议事务快10倍.GTS有哪些功能,相比传统事务的优势在哪呢?我们通

一张图读懂Java多线程

1.带着疑问看图 1)竞争对象的锁和竞争CPU资源以及竞争被唤醒 2)何种情况下获取到了锁,何种情况下会释放锁 2.还是那张图 3.详细图解 1)Thread t = new Thread(),初始化一个线程,实际上就是一个普通对象,此时他的状态为New 2)t.start(); 线程处于就绪状态(可运行状态),也就是随时等待着运行, 不要小看这个start,这个start决定了他是否是一个真正的线程实例,因为start为其准备了线程环境,你若只是普通调用run方法,那么这就是 一个普通的方法.

一张图读懂IO流 (java)不要错过!

IO流的选择是开发中经常遇到的问题?下面是一张高度总结的IO流图,一张图搞定! ------------------------------------------------------------------------------------------------------------------------------------------- ----具体文字解释---未完待续....

一张图读懂今日头条推荐机制

影响推荐量的因素是比较复杂的,总体来说投入运营精力更大,内容质量越高,推荐效果就越好. 当然,这是个大道理,关系的是内功.具体到短期内的推荐量增长,还是需要一些hack式的技巧: 1.内容是给人看的,但首先机器要能读懂,目前基本上机器只能理解文字,所以你的内容是给哪部分受众看的,一定要表达清楚,比如你是写足球的,你就少提科比,你就少写段子,否则机器理解错了,推错人群,读者不感兴趣,点击率一点,很快就不推荐了. 2.读者停留很重要,点进去就退出来的点击是无效的,甚至是负面效果.所以标题党要有限度,

八张图读懂未来“互联网+”的六大趋势

1 虽然“互联网”一词在当下伴随着鼓吹与泡沫而炙手可热,但毋庸置疑的是,互联网将成为人类下一次飞跃的桥梁和动力毋庸置疑.钛媒体作者薄云借智用八张图互联网未来发展的六大趋势:连接与聚合.产业互联网化.产业金融化.个性化需求.O2O.智能工业. 趋势一:连接与聚合 趋势二:产业互联网化 趋势三:产业金融化 趋势四:个性化需求 趋势五:O2O将成为服务互联网的主要方式 趋势六:智慧工业时代 出自:http://money.163.com/15/0506/14/AOUIJQ7U00253B0H.html

一张图读懂基于微信硬件平台的物联网架构

本文从物联网的核心要素.物联网的关键场景.微信硬件平台的通信协议分析三个维度去分析基于微信硬件平台的物联网架构.相关的背景知识请阅读微信公众号:嵌入式企鹅圈发布的有关物联网和微信硬件专题文章. 一. 基于微信硬件平台的物联网架构图示 上图涵盖以下信息: 1.   基于微信硬件平台的物联网的架构组成,有微信公众平台/硬件平台.第三方厂商云后端.手机微信/公众号.微信硬件设备终端(Wifi和蓝牙BLE). 2.   绿色代表腾讯向开发者和公众提供的基础平台和服务,并通过红色(airsync/airk

一张图读懂虚拟化的发展历史,看VMware Horizon如何紧跟Citrix的步伐

经常碰到有朋友问我Citrix和VMware公司区别,为了还原一个真相,博主特意整理了两家公司的异同,特别是公司的起家史.由于Citrix是桌面虚拟化和应用虚拟化的业内翘楚,我们着重分析的是这两家公司在桌面虚拟化和应用虚拟化的发展历史,如有错误还请大家指正. 公司大事记 我们先看看两家公司里程碑的几个时间点吧. 公司成立时间:Citrix在1989年,VMware在1998年: 公司上市时间(IPO):Citrix在1995年,VMware在2007年: 共享桌面虚拟化(应用虚拟化的一种)发布时

从两张图读懂互联网彩票停售起因

为何互联网彩票多次被"叫停"?背后的真正原因在哪?纵观目前所有的报道,似乎都未触及其"实质".唯彩会发现互联网彩票屡屡"叫停",而又屡屡放行背后的真正原因在于两点: 一是,彩票这个传统业态下的特殊商品,"穿"上互联网尤其是移动互联网的"衣服"后,立马改变了原有的利益格局. 二是,对于迅速膨胀的互联网彩票带来的新增利益(未来将是最主要的)如何"把控"并重新有效的分配,似乎目前仍未找到很好的

一张图读懂数据库备份

摘要: 数据库备份DBS已于5月17日正式商业化,DBS旨在提供高性价比的数据库实时备份服务,更多详情查看:https://promotion.aliyun.com/ntms/act/dbs.html 原文链接 原文地址:http://blog.51cto.com/13679539/2122147