1.先看一下例子程序:
import java.io.IOException; import java.net.ServerSocket; import javax.rmi.CORBA.Tie; /* *@author: ZhengHaibo *web: http://blog.csdn.net/nuptboyzhb *mail: [email protected] *2014-3-16 Nanjing,njupt,China */ public class TestThread { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Thread t1=new Thread(){ @Override public void run(){ try { int i=0; while (i++<100000000){ //nothing } System.out.println("A1"); } catch (Exception e) { // TODO: handle exception System.out.println("B1"); } } }; t1.start(); t1.interrupt();//无法中断正在运行的线程 try { t1.join(); } catch (InterruptedException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } Thread t2=new Thread(){ @Override public void run(){ try { Thread.sleep(5000); System.out.println("A2"); } catch (Exception e) { // TODO: handle exception System.out.println("B2 "+e.toString()); } } }; t2.start(); t2.interrupt();//可以中断正在休眠的线程,并抛出异常 try { t2.join(); } catch (InterruptedException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } Thread t3=new Thread(){ @Override public void run(){ try { this.wait(5000); System.out.println("A3"); } catch (Exception e) { // TODO: handle exception System.out.println("B3 "+e.toString()); } } }; t3.start(); t3.interrupt(); try { t3.join(); } catch (InterruptedException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } Thread t4=new Thread(){ @Override public void run(){ try { synchronized (this) { this.wait(5000); } System.out.println("A4"); } catch (Exception e) { // TODO: handle exception System.out.println("B4 "+e.toString()); } } }; t4.start(); t4.interrupt(); try { t4.join(); } catch (InterruptedException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } try { final ServerSocket serverSocket=new ServerSocket(8080); Thread t5=new Thread(){ @Override public void run(){ try { serverSocket.accept(); System.out.println("A5"); } catch (Exception e) { // TODO: handle exception System.out.println("B5 "+e.toString()); } } }; t5.start(); t5.interrupt();//无法中断 t5.stop();//线程停止 } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } try { t4.start(); System.out.println("A6"); } catch (Exception e) { // TODO: handle exception System.out.println("B6 "+ e.toString()); } } }
运行结果为:
A1 B2 java.lang.InterruptedException: sleep interrupted B3 java.lang.IllegalMonitorStateException B4 java.lang.InterruptedException B6 java.lang.IllegalThreadStateException
1、这两个方法来自不同的类分别是,sleep来自Thread类,和wait来自Object类。
sleep是Thread的静态类方法,谁调用的谁去睡觉,即使在a线程里调用了b的sleep方法,实际上还是a去睡觉,要让b线程睡觉要在b的代码中调用sleep。
2、最主要是sleep方法没有释放锁,而wait方法释放了锁,使得其他线程可以使用同步控制块或者方法。
sleep不出让系统资源;wait是进入线程等待池等待,出让系统资源,其他线程可以占用CPU。一般wait不会加时间限制,因为如果wait线程的运行资源不够,再出来也没用,要等待其他线程调用notify/notifyAll唤醒等待池中的所有线程,才会进入就绪队列等待OS分配系统资源。sleep(milliseconds)可以用时间指定使它自动唤醒过来,如果时间不到只能调用interrupt()强行打断。
Thread.Sleep(0)的作用是“触发操作系统立刻重新进行一次CPU竞争”。
3、使用范围:wait,notify和notifyAll只能在同步控制方法或者同步控制块里面使用,而sleep可以在任何地方使用
synchronized(x){
x.notify()
//或者wait()
}
4、sleep必须捕获异常,而wait,notify和notifyAll不需要捕获异常
相关博客:
java并发编程相关博客:
[3].Java并发性和多线程介绍目录http://ifeve.com/java-concurrency-thread-directory/
[4]volatile的使用:http://www.ibm.com/developerworks/cn/java/j-jtp06197.html