java线程(Thread)——wait、sleep、notify、线程的生命周期、状态

来源:互联网 发布:百度地图提示网络异常 编辑:程序博客网 时间:2024/06/08 03:50

还是从代码中根据实例进行分析线程的中断:

package LyfPractice;/** * Created by fangjiejie on 2016/12/15. */public class SThread {}class S extends Thread{    @Override    public void run() {        for(int i=0;i<1000;i++){            if(i==100){//                1.Thread.currentThread().stop();不推荐使用//                try {//                    Thread.currentThread().sleep(Long.MAX_VALUE);//2.也是比较耗费内存的//                                              sleep(1000)里面的时间也是可以自己控制的//                } catch (InterruptedException e) {//                    e.printStackTrace();//                }                break;//3.推荐使用            }            System.out.println(Thread.currentThread().getName()+": "+i);        }    }}

用法:
sleep() :
在指定的毫秒数内让当前正在执行的线程休眠(暂停执行),此操作受到系统计时器和调度程序精度和准确性的影响。
由于sleep()方法是Thread类的方法,因此它不能改变对象的机锁。所以当在一个Synchronized方法中调用sleep()时,线程虽然休眠了,但是对象的机锁没有被释放,其他线程仍然无法访问这个对象。sleep()方法不需要在同步的代码块中执行。但是sleep()可以通过interrupt()方法打断线程的暂停状态,从而使线程立刻抛出InterruptedException。

wait():
wait()方法则会在线程休眠的同时释放掉机锁,其他线程可以访问该对象。wait()必须在同步的代码块中执行。当一个线程执行到wait()方法时,它就进入到一个和该对象相关的等待池中,同时失去了对象的机锁,可以允许其它的线程执行一些同步操作。但是wait()可以通过interrupt()方法打断线程的暂停状态,从而使线程立刻抛出InterruptedException。

notify():
notify()唤醒在此对象监视器上等待的单个线程。当它被一个notify()方法唤醒时,等待池中的线程就被放到了锁池中。该线程将等待从锁池中获得机锁,然后回到wait()前的中断现场。
notifyAll()唤醒在此对象监视器上等待的所有线程。

wait()和sleep()的区别:
调用wait()方法,线程会放弃对象锁,进入等待此对象的等待锁定池。只有针对此对象调用notify()方法后本线程才进入对象锁定池准备获取对象锁进入运行状态。但是如果没有调用notify()方法,则线程永远处于挂起状态。
sleep()方法导致了程序暂停执行指定的时间,让出cpu该其他线程,但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。在调用sleep()方法的过程中,线程不会释放对象锁。

这里写图片描述

线程的生命周期:
这里写图片描述
线程的状态:
以下感谢转自http://zy19982004.iteye.com/blog/1626916
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

1 0