还是从代码中根据实例进行分析线程的中断:
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