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

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

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
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值