概述
线程共有六种状态
- 初始状态
实现Runnable接口和继承Thread可以得到一个线程类,new一个实例出来,线程就进入了初始状态。
2.1. 就绪状态
就绪状态只是说你资格运行,调度程序没有挑选到你,你就永远是就绪状态。
调用线程的start()方法,此线程进入就绪状态。
当前线程sleep()方法结束,其他线程join()结束,等待用户输入完毕,某个线程拿到对象锁,这些线程也将进入就绪状态。
当前线程时间片用完了,调用当前线程的yield()方法,当前线程进入就绪状态。
锁池里的线程拿到对象锁后,进入就绪状态。
2.2. 运行中状态
线程调度程序从可运行池中选择一个线程作为当前线程时线程所处的状态。这也是线程进入运行状态的唯一一种方式。
-
阻塞状态
阻塞状态是线程阻塞在进入synchronized关键字修饰的方法或代码块(获取锁)时的状态。 -
等待
处于这种状态的线程不会被分配CPU执行时间,它们要等待被显式地唤醒,否则会处于无限期等待的状态。 -
超时等待
处于这种状态的线程不会被分配CPU执行时间,不过无须无限期等待被其他线程显示地唤醒,在达到一定时间后它们会自动唤醒。 -
终止状态
当线程的run()方法完成时,或者主线程的main()方法完成时,我们就认为它终止了。这个线程对象也许是活的,但是,它已经不是一个单独执行的线程。线程一旦终止了,就不能复生。
在一个终止的线程上调用start()方法,会抛出java.lang.IllegalThreadStateException异常。
1.创建新线程并调用start方法,线程进入runnable(可运行)状态,如果抢占到cpu资源,线程进入running(运行)状态。
2.线程进入可运行状态有五种情况
1.调用sleep方法超过指定休眠时间
2.线程调用的阻塞io已经返回,阻塞方法执行完毕
3.线程获得了试图同步的监视器
4.线程正在等待通知,其他线程发出通知
5.处于挂起状态的线程调用了resume方法
3.线程处于阻塞状态,也称暂停状态或blockec,blocked结束后,进入runnable状态,等待系统重新分配资源
1.线程调用sleep
2.线程调用阻塞io
3.试图获得同步监视器
4.线程等待某个通知
5.调用了suspend方法,此方法容易死锁,尽量避免
同步监视器:简单来说,监视器用来确保同一时间只能有一个线程可以访问特定的数据和代码。
run方法结束后进入销毁阶段
每个锁对象都有两个队列,一个是就绪,一个是阻塞,就绪队列存储将要得到锁的线程。一个线程被wait后,就进入阻塞队列。
重要的特性方法
1.sleep方法不会释放锁,sleep是Thread类的方法,wait是Object的方法。
2.wait方法会释放锁,wait(long)是等待某一时间内是否有线程对锁进行唤醒,如果超过这个时间自动唤醒
3.nodify方法不会释放锁,并且只能随机唤醒一个线程
wait/notify模式有两种情况会造成程序逻辑混乱
1.执行wait的条件发生改变
2.线程执行notify的时候,需要被唤醒的线程还有执行wait
最后
以上就是不安豌豆为你收集整理的线程的状态的全部内容,希望文章能够帮你解决线程的状态所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复