java 线程 状态 图_Java提高——多线程(一)状态图

操作系统中的进程和线程的概念

进程是指一个内存运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程中可以启动多个线程,比如windows下的一个运行的应用程序.exe就是一个进程。

线程是指进程中的一个执行流,一个进程可以运行多个线程。如java.exe就可以运行很多个线程。线程总是属于某个进程,进程中的多个线程共享进程中的内存。

操作系统中可以同时执行多个任务,每个任务就是进程;进程可以同时执行多个任务,每个任务就是线程。

线程的状态

85e71d9c51e86db3b661896ce2a06815.png

1、新建(new):线程对象被创建后就进入了新建状态。如:Thread thread = new Thread();

2、就绪状态(Runnable):也被称为“可执行状态”。线程对象被创建后,其他线程调用了该对象的start()方法,从而启动该线程。如:thread.start(); 处于就绪状态的线程随时可能被CPU调度执行。

3、运行状态(Running):线程获取CPU权限进行执行。需要注意的是,线程只能从就绪状态进入到运行状态。

4、阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃CPU使用权限,暂时停止运行。直到线程进入就绪状态,才有机会进入运行状态。阻塞的三种情况:

1)等待阻塞:通过调用线程的wait()方法,让线程等待某工作的完成。

2)同步阻塞:线程在获取synchronized同步锁失败(因为锁被其他线程占用),它会进入同步阻塞状态。

3)其他阻塞:通过调用线程的sleep()或join()或发出了I/O请求时,线程会进入到阻塞状态。当sleep()状态超时、join()等待线程终止或超时、或者I/O处理完毕时,线程重新转入就绪状态。

5、死亡状态(Dead):线程执行完了或因异常退出了run()方法,该线程结束生命周期。

常用的实现多线程的方式

1、继承Thread类publicclassThread implementsRunnable {、、、、、}

由Thread的源码可以看出,Thread是实现了Runnable接口。

2、实现Runnable接口

publicinterfaceRunnable {

public abstract voidrun();}

Runnable接口只有一个run()方法

————————————————————————————————————————————————

Thread和Runnable都是是实现实现多线程的方式。不同的是Thread是类,Runnable是接口——Thread本身实现了Runnable接口,一个类只能有一个父类,但是却可以是实现多个接口,因此Runnable具有更好的扩展性。

Thread实现多线程public classMyThread extendsThread {

private inti;@Override/** 重写run方法*/public voidrun(){

for(inti = 0;i < 50;i++) {

/*** 当继承Thread类可以直接用this获取当前线程* 用getName()获取当前线程的名字*/System.out.println(this.getName()+"-"+i);}

}

public static voidmain(String[] args) {

for(inti = 0;i < 100;i++) {

//通过Thread.currentThread()获取当前线程System.out.println(Thread.currentThread().getName()+" "+i);if(i==20){

//创建并启动第一个线程newMyThread().start();//创建并启动第二个线程newMyThread().start();}

}

}

}

Runnable实现多线程public classMyRunnable implementsRunnable {

private inti;@Overridepublic voidrun() {

for(inti = 0;i < 50;i++) {

/**当线程类实现Runnable接口的时候,获取当前线程只能用Thread.currentThread()*/System.out.println(Thread.currentThread().getName()+" "+i);}

}

public static voidmain(String[] args) {

for(inti = 0;i < 100;i++) {

// System.out.println(Thread.currentThread().getName()+" "+i);if(i==20){

MyRunnable mr = newMyRunnable();//通过new Start()方法创建新线程newThread(mr,"线程1").start();newThread(mr,"线程2").start();}

}

}

}

关于线程中的start()和run()

启动线程使用start(),而不是run()!

4ab52dfa8b9eabd8229a14f581e3f376.png

在执行start()方法之前,只是有一个Thread对象,还没一个真正的线程。(分配内存,初始化成员变量)

——>start()之后,线程状态从新状态到可执行状态。(调用栈和计数器,线程没运行,只是可以运行)

——>当线程获得执行机会时,其目标run()方法将运行。

start():他的作用是启动一个新线程,新线程会调用相应的run()方法。start()不能被重复调用。

run():和普通成员的方法一样可以被重复调用。单独调用run()会在当前线程中执行run(),而不会启动新的线程。

public classMyThread extendsThread {@Override/** 重写run方法*/public voidrun(){

}

}

MyThread myThread = new MyThread();

如:myThread.start()会启动一个新的线程,然后在新线程中执行run()方法。

myThread.run()会直接在当前线程中运行run()方法,不会启动一个线程。

start方法源码:public synchronized voidstart() {

/**

*如果线程不是就绪状态就抛出异常*/if(threadStatus!= 0)

throw newIllegalThreadStateException();/* 将线程添加到group当中 */group.add(this);booleanstarted = false;try{

start0();//通过start0启动线程started = true;//设置started标记} finally{

try{

if(!started) {

group.threadStartFailed(this);}

} catch(Throwable ignore) {

/* do nothing. If start0 threw a Throwable thenit will be passed up the call stack */}

}

}

run方法源码:public voidrun() {

if(target!= null) {

target.run();}

}

其中target是Runnable对象, 直接调用Thread线程中Runnable接口中run方法,不会新建一个线程。

当线程获得CPU,开始执行run()方法的线程执行体,则该线程处于运行状态。

关于阻塞

e266c4317886029c7858c6f8bb4841b1.png

进入阻塞的情况:解除上面阻塞情况:

1、线程调用sleep()方法主动释放占用的处理器资源

2、调用了一个阻塞式的IO方法,在方法返回前线程被阻塞

3、线程获得了一个同步监视器(Syschronized),但该监视器正被其他线程持有

4、线程在等待某个通知(notify)

5、程序调用了线程的resume()方法将线程挂起。但是该方法容易发生死锁,所以尽量避免使用1、调用sleep()方法经过了指定的时间

2、线程调用的IO阻塞方法已经返回

3、线程成功的获得了试图取得的同步监视器

4、线程正在等待某个通知时,其他线程发出了一个通知

5、处于挂起的线程被调用了resume()恢复方法。

线程从阻塞状态只能进入就绪状态,无法进入运行状态,而从就绪到运行不受程序控制,由系统线程调度决定。

获得资源进入运行状态,失去资源进入就绪状态。

线程死亡

e6ba587fd6b1738b78ba8908964a7409.png

线程死亡会以一下三种状况结束:

—>调用run或call方法执行完成,正常结束

—>线程抛出一个为捕获的Exception或Error

—>直接调用stop()方法来结束该线程——容易导致死锁,不推荐。

不要试图对死亡的线程使用start()方法,将会抛出异常,并不会重启死亡的异常!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/459793.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

幽幽的灵光射不出你想要的疯狂

秋天到了&#xff0c;忧伤便无处可逃&#xff0c;秋天的忧伤的气息&#xff0c;就像一个妖艳的美女躺在你的身边&#xff0c;让你热血沸腾&#xff0c;冲动无比&#xff0c;而又悲喜交加&#xff0c;忧愁满地。如果不信&#xff0c;你可以试试。分享一首去年的诗歌&#xff0c;…

找规律

找规律填写NN方阵。如N8时, 其方阵为: 1 1 1 1 1 1 1 11 2 2 2 2 2 2 11 2 3 3 3 3 2 11 2 3 4 4 3 2 11 2 3 4 4 3 2 11 2 3 3 3 3 2 11 2 2 2 2 2 2 11 1 1 1 1 1 1 1 上代码&#xff1a; 1 #include <stdio.h&g…

arm qt5 iconv 问题

2019独角兽企业重金招聘Python工程师标准>>> 问题 3&#xff1a;./system/rootlib/helloworld -qws &#xff0c;程序运行起来&#xff0c;仍报错 QIconvCodec::convertFromUnicode: using Latin-1 for conversion, iconv_open failed …

[转]用Whois获得电信运营商的IP地址是如何分配的?

[转]用Whois获得电信运营商的IP地址是如何分配的? Linux下获得一些中国电信运营商的IP地址分配情况: APNIC是管理亚太地区IP地址分配的机构&#xff0c;它有着丰富准确的IP地址分配库&#xff0c;同时这些信息也是对外公开的&#xff0c;并提供了一个查询工具&#xff0c;下面…

庆祝教师节,李宁老师课程优惠劵疯抢中、会员卡优惠中,先到先得

李宁老师会员卡&#xff08;9-10至9-14&#xff09;大优惠&#xff1a;http://edu.51cto.com/member/id-12_1.html优惠劵只能购买李宁老师的视频课程&#xff1a;http://edu.51cto.com/member/id-12_1.html 优惠劵有效期&#xff1a;2015-9-10 至 2015-9-14 购买规则&#xf…

java mset_Java 反射机制(包括组成、结构、示例说明等内容)

第1部分 Java 反射机制介绍Java 反射机制。通俗来讲呢&#xff0c;就是在运行状态中&#xff0c;我们可以根据“类的部分已经的信息”来还原“类的全部的信息”。这里“类的部分已经的信息”&#xff0c;可以是“类名”或“类的对象”等信息。“类的全部信息”就是指“类的属性…

自己动手,实现一种类似ListT的数据结构(二)

前言&#xff1a; 首先&#xff0c;小匹夫要祝各位看官圣诞快乐&#xff0c;新年愉快&#xff5e;。上一篇文章《自己动手&#xff0c;实现一种类似List<T>的数据结构(一&#xff09;》 介绍了一下不依靠List<T>实现的各种接口&#xff0c;仿造一个轻量级数据结构的…

局域网内连接MySQL

2019独角兽企业重金招聘Python工程师标准>>> 局域网内连接MySQL 博客分类&#xff1a; MySQL MySQL局域网连接grant 我们都知道连接MySQL一般用的语句就是 jdbc:mysql://localhost:3306/database&#xff0c; 但是当你要连接到其他机器上的mysql的时候&#xff0c;…

[leetcod] Clone Graph

题目&#xff1a; Clone an undirected graph. Each node in the graph contains a label and a list of its neighbors. OJs undirected graph serialization: Nodes are labeled uniquely. We use # as a separator for each node, and , as a separator for node label and …

【iOS7一些总结】9、与列表显示(在):列表显示UITableView

列表显示&#xff0c;顾名思义它是在一个列表视图的形式显示在屏幕上的数据的内容。于ios在列表视图UITableView达到。这个类在实际应用中频繁&#xff0c;是很easy理解。这里将UITableView的主要使用方法总结一下以备查。UITableView定义在头文件UITableView.h中&#xff0c;详…

SpringMVC(一):环境搭建

2019独角兽企业重金招聘Python工程师标准>>> //TODO 转载于:https://my.oschina.net/u/1020238/blog/505272

DockPanel 类

DockPanel 类 .NET Framework 4.5其他版本此主题尚未评级 - 评价此主题定义您可水平或垂直排列子元素的区域&#xff0c;互相。 继承层次结构 System.Object System.Windows.Threading.DispatcherObjectSystem.Windows.DependencyObjectSystem.Windows.Media.VisualSystem.Wind…

【分布式计算】MapReduce的替代者-Parameter Server

原文&#xff1a;http://blog.csdn.net/buptgshengod/article/details/46819051 首先还是要声明一下&#xff0c;这个文章是我在入职阿里云1个月以来&#xff0c;对于分布式计算的一点肤浅的认识&#xff0c;可能有些地方不够妥善&#xff0c;还请看官可以指出不足的地方&#…

iOS开发多线程篇—线程安全

iOS开发多线程篇—线程安全 一、多线程的安全隐患 资源共享 1块资源可能会被多个线程共享&#xff0c;也就是多个线程可能会访问同一块资源 比如多个线程访问同一个对象、同一个变量、同一个文件 当多个线程访问同一块资源时&#xff0c;很容易引发数据错乱和数据安全问题 示例…

Android Ion 框架 文件下载

为什么80%的码农都做不了架构师&#xff1f;>>> ion是的一个安卓异步网络和图片加载库。 特性 异步下载&#xff1a;下载图片 (用ImageViews 或者 Bitmaps显示)&#xff1b;下载JSON文件 (通过Gson解析)&#xff1b;下载字符串&#xff1b;下载文件&#xff1b;Flu…

CSS基础----元素分类

2019独角兽企业重金招聘Python工程师标准>>> 块级元素特点&#xff1a; 1、每个块级元素都从新的一行开始&#xff0c;并且其后的元素也另起一行。 2、元素的高度、宽度、行高以及顶和底边距都可设置。 3、元素宽度在不设置的情况下&#xff0c;是它本身父容器的100…

Linux 高可用(HA)集群之keepalived

一、keepalived介绍1、Keepalived 定义Keepalived 是一个基于VRRP协议来实现的LVS服务高可用方案&#xff0c;可以利用其来避免单点故障。一个LVS服务会有2台服务器运行Keepalived&#xff0c;一台为主服务器&#xff08;MASTER&#xff09;&#xff0c;一台为备份服务器&#…

java 将要死亡_人在即将死亡的时候,能意识到自己将要死亡了吗?科学家给出答案...

引言&#xff1a;自然界内大多数生物都敬畏生命&#xff0c;也害怕死亡。毕竟&#xff0c;死亡意味着结束与告别&#xff0c;将死之人多会留恋世间的人或事。那么&#xff0c;在临死之前&#xff0c;人会意识到自己将走向死亡吗&#xff1f;人类对长生不老的追求古已有之&#…

C#开发微信门户及应用(24)-微信小店货架信息管理

C#开发微信门户及应用(24)-微信小店货架信息管理 原文:C#开发微信门户及应用(24)-微信小店货架信息管理在前面微信小店系列篇《C#开发微信门户及应用(22)-微信小店的开发和使用》里面介绍了一些微信小店的基础知识&#xff0c;以及《C#开发微信门户及应用(23)-微信小店商品管理…

【百度地图API】——如何用label制作简易的房产标签

【百度地图API】——如何用label制作简易的房产标签 原文:【百度地图API】——如何用label制作简易的房产标签摘要&#xff1a; 最近&#xff0c;API爱好者们纷纷说&#xff0c;自定义marker太复杂了&#xff01;不仅定义复杂&#xff0c;连所有的dom事件都要自己重新定义。有没…