sleep():正在执行的线程主动让出CPU(然后CPU就可以去执行其他任务),在sleep指定时间后CPU再回到该线程继续往下执行。注意:sleep方法只让出了CPU,而并不会释放同步资源锁!!!
wait():则是指当前线程让自己暂时退让出同步资源锁,以便其他正在等待该资源的线程得到该资源进而运行,只有调用了notify()方法,之前调用wait()的线程才会解除wait状态,可以去参与竞争同步资源锁,进而得到执行。注意:notify的作用相当于叫醒睡着的人,而并不会给他分配任务,就是说notify只是让之前调用wait的线程有权利重新参与线程的调度!!!
以程序说明:
- public class MultiThread {
-
- private static class Thread1 implements Runnable{
- @Override
- public void run() {
-
-
- synchronized(MultiThread.class){
- System.out.println("enter thread1 ...");
- System.out.println("thread1 is waiting");
-
- try{
-
-
- MultiThread.class.wait();
- }catch(InterruptedException e){
- e.printStackTrace();
- }
-
- System.out.println("thread1 is going on ...");
- System.out.println("thread1 is being over!");
- }
- }
-
- }
-
- private static class Thread2 implements Runnable{
- @Override
- public void run() {
-
-
- synchronized(MultiThread.class){
- System.out.println("enter thread2 ...");
- System.out.println("thread2 notify other thread can release wait status ...");
- MultiThread.class.notify();
- System.out.println("thread2 is sleeping ten millisecond ...");
-
- try{
- Thread.sleep(10);
- }catch(InterruptedException e){
- e.printStackTrace();
- }
-
- System.out.println("thread2 is going on ...");
- System.out.println("thread2 is being over!");
- }
- }
- }
-
- public static void main(String[] args) {
- new Thread(new Thread1()).start();
- try{
- Thread.sleep(10);
- }catch(InterruptedException e){
- e.printStackTrace();
- }
-
- new Thread(new Thread2()).start();
- }
-
- }
程序运行结果如下图所示