java笔记--关于多线程状态的理解和应用
关于多线程的状态
--如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/3890266.html "谢谢--
线程共有6种状态:
1.新建线程---使用new来新建一个线程
2.运行线程---调用start()方法,线程处于运行或可运行状态
3.线程阻塞---线程需要获得内置锁,当该锁被其他线程使用时,此线程处于阻塞状态
4.线程等待---当线程等待其他线程通知调度表可以运行时,此时线程处于等待状态
5.线程计时等待---当线程调用含有时间参数的方法(如sleep())时,线程可进入计时等待状态
6.终止线程--当线程的run()方法结束或者出现异常时,线程处于终止状态
注意:在写多线程程序时,要时刻注意线程的状态,不同状态下,线程能够执行的任务是不同的
使用Thread类的getState()方法可以获取到线程的状态,该方法的返回值是Thread.State,
它是线程状态类的枚举。如下表:
枚举常量 含义
NEW 新建状态
RUNNABLE 运行(可运行)状态
BLOCKED 阻塞状态
TIMED_WAITING 休眠状态
WAITING 等待状态
TERMINATED 终止状态
常用方法:
wait(): 让线程等待
notify():唤醒一个线程
notifyAll():唤醒所有线程
sleep():让线程休眠
interrupt():中断线程
yield():暂停当前线程执行其他线程
代码例子:
实现并输出当前线程的状态:
package com.xhj.thread;
/**
* 获取线程状态
*
* @author XIEHEJUN
*
*/
public class ThreadState implements Runnable {
public synchronized void waitForASecond() throws InterruptedException {
wait(500);
}
public synchronized void waiting() throws InterruptedException {
wait();
}
public synchronized void notifyNow() throws InterruptedException {
notify();
}
@Override
public void run() {
try {
waitForASecond();
waiting();
} catch (Exception e) {
System.out.println(e.getMessage());
}
}
public static void main(String[] args) throws InterruptedException {
ThreadState state = new ThreadState();
Thread thread = new Thread(state);
System.out.println("新建线程:" + thread.getState());
thread.start();
System.out.println("线程运行:" + thread.getState());
Thread.sleep(100);
System.out.println("计时等待线程:" + thread.getState());
Thread.sleep(1000);
System.out.println("等待线程:" + thread.getState());
state.notifyNow();
System.out.println("唤醒线程:" + thread.getState());
Thread.sleep(1000);
System.out.println("终止线程:" + thread.getState());
}
}
java笔记--关于多线程状态的理解和应用的更多相关文章
- java笔记--对信号量Semaphore的理解与运用
java Semaphore 信号量的使用: 在java中,提供了信号量Semaphore的支持. Semaphore类是一个计数信号量,必须由获取它的线程释放, 通常用于限制可以访问某些资源(物理或 ...
- JAVA笔记14__多线程共享数据(同步)/ 线程死锁 / 生产者与消费者应用案例 / 线程池
/** * 多线程共享数据 * 线程同步:多个线程在同一个时间段只能有一个线程执行其指定代码,其他线程要等待此线程完成之后才可以继续执行. * 多线程共享数据的安全问题,使用同步解决. * 线程同步两 ...
- java笔记--关于多线程如何查看JVM中运行的线程
查看JVM中的线程 --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/3890280.html "谢谢-- ThreadGrou ...
- java笔记--局部内部类认识与理解
java内部类 内部类应用最多的场景是在编写GUI程序时,将大量的事件监听处理放在了内部类中进行 --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XH ...
- java笔记--匿名内部类和静态内部类的理解和使用
匿名内部类 --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/3889467.html "谢谢-- 1.由于局部内部类并不可见 ...
- [译]线程生命周期-理解Java中的线程状态
线程生命周期-理解Java中的线程状态 在多线程编程环境下,理解线程生命周期和线程状态非常重要. 在上一篇教程中,我们已经学习了如何创建java线程:实现Runnable接口或者成为Thread的子类 ...
- Java线程Thread的状态解析以及状态转换分析 多线程中篇(七)
线程与操作系统中线程(进程)的概念同根同源,尽管千差万别. 操作系统中有状态以及状态的切换,Java线程中照样也有. State 在Thread类中有内部类 枚举State,用于抽象描述Java线程的 ...
- 多线程系列之 java多线程的个人理解(二)
前言:上一篇多线程系列之 java多线程的个人理解(一) 讲到了线程.进程.多线程的基本概念,以及多线程在java中的基本实现方式,本篇主要接着上一篇继续讲述多线程在实际项目中的应用以及遇到的诸多问题 ...
- Java四种引用--《深入理解Java虚拟机》学习笔记及个人理解(四)
Java四种引用--<深入理解Java虚拟机>学习笔记及个人理解(四) 书上P65. StrongReference(强引用) 类似Object obj = new Object() 这类 ...
随机推荐
- 终于解决了贴吧手机版的一个重大BUG
终于解决了贴吧手机版的一个重大BUG 别诧异虽然同一个域名,但是,PC 和手机打开完全不一样的体验 http://tieba.yunxunmi.com/ 吃点夜校准备做梦去!! 发现 我云贴吧 一个 ...
- feign中的hytrix和turbin配置
这里我用了两个生产者和两个消费者进行演示,如下图(画的不好看,凑活看看): 这里我就只讲下怎么注册到dashbord和相关的配置,提供者和消费者等代码可以去下载查看: https://github.c ...
- 用Akka构建一个简易的分布式文件系统
本来初期打算用Hadoop 2,可是后来有限的服务器部署了Solr Cloud,各种站点,发现资源不够了,近10T的文件,已经几乎把服务器的磁盘全部用光.想来想去,由于目前架构基于Scala的,所以还 ...
- 【Qt开发】常用控件--QSpinBox和QDoubleSpinBox
QSpinBox和QDoubleSpinBox 是UI设计常用的控件. QSpinBox可用于显示和输入整数,并可以在显示框中添加前缀或后缀. QDoubleSpinBox可用于显示和输入小数,并可以 ...
- linux mint19 解决docker必须使用sudo问题
1 安装完docker 使用时,提示权限不够 ~$ docker info Got permission denied while trying to connect to the Docker da ...
- ActionController::UnfilteredParameters: unable to convert unpermitted parameters to hash
rails 开发中 5.1版本使用binding.pry会报 ActionController::UnfilteredParameters: unable to convert unpermitted ...
- [中英对照]Why Redis beats Memcached for caching | 在cache化方面,为何Redis胜过Memcached?
对Memcached和Redis有兴趣的同学不妨花几分钟读一读本文,否则请飘过. Why Redis beats Memcached for caching | 在cache化方面,为何Redis胜过 ...
- jqGrid资源
在比较多个Grid后决定以后还是用jqGrid,并且是free-jqgrid分支版, jqgrid优点很多: 加载大量数据时效率很好, 支持排序, 支持过滤, 支持resize, 支持分页, 支持e ...
- JMM随笔
What? Java内存模型(Java Memory Model,JMM)主要是为了规定了线程和内存之间的一些关系. 根据JMM的设计: 系统存在一个主内存(Main Memory),Java中所有变 ...
- [PY3]——IO——文件读写
文件打开和关闭 # 使用open 打开文件,返回时值是一个 File-like对象 f.open('/test/file') # 使用read读取文件 f.read( ) # 使用close关闭文件 ...