• Java中的对象Object方法之---wait()和notifiy() 分类: Java Android 2014-02-26 08:50 1599人阅读 评论(0) 收藏


    上一篇说到了suspend()和resume()方法,这一篇咋们继续,接着来介绍wait()和notify()方法,我们都知道这两个方法和之前介绍的方法不太一样,那就是这两个方法是对象Object上的,不属于Thread类上的。我们也知道这两个方法是实现多个线程之间的通信和互斥的,不多说了,下面就来看一下例子吧:

    例子描述:

    开启两个线程,子线程循环10次,主线程循环100次,如此反复循环50次

    代码如下:

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
    1. package cn.itcast.heima;  
    2.   
    3. public class TraditionalThreadCommunication {  
    4.   
    5.     public static void main(String[] args) {  
    6.         final Business business = new Business();  
    7.         //子线程循环10次  
    8.         new Thread(new Runnable(){  
    9.             @Override  
    10.             public void run() {  
    11.                 for(int i=0;i<50;i++){  
    12.                     business.sub(i);  
    13.                 }  
    14.             }  
    15.         }).start();  
    16.           
    17.         //主线程循环100次  
    18.         for(int i=0;i<50;i++){  
    19.             business.main(i);  
    20.         }  
    21.           
    22.     }  
    23.       
    24.     /** 
    25.      * 业务逻辑类 
    26.      * @author weijiang204321 
    27.      * 
    28.      */  
    29.     static class Business{  
    30.         private boolean bShouldSub = true;//true表示sub执行,false表示main执行  
    31.         public synchronized void sub(int i){  
    32.             //将这里的if改成while,效果更好,while会再次判断,安全性高  
    33.             //因为有时候线程可能被假唤醒  
    34.             while(!bShouldSub){  
    35.                 try {  
    36.                     //等待  
    37.                     this.wait();  
    38.                 } catch (InterruptedException e) {  
    39.                     e.printStackTrace();  
    40.                 }  
    41.             }  
    42.               
    43.             for(int j=0;j<=10;j++){  
    44.                 System.out.println("sub thread sequece of" + j + ",loop of"+i);  
    45.             }  
    46.             bShouldSub = false;  
    47.             this.notify();//唤醒该锁的等待线程  
    48.         }  
    49.           
    50.         public synchronized void main(int i){  
    51.             while(bShouldSub){  
    52.                 try {  
    53.                     this.wait();  
    54.                 } catch (InterruptedException e) {  
    55.                     e.printStackTrace();  
    56.                 }  
    57.             }  
    58.             for(int j=0;j<=100;j++){  
    59.                 System.out.println("main thread sequece of" + j + ",loop of"+i);  
    60.             }  
    61.             bShouldSub = true;  
    62.             this.notify();  
    63.         }  
    64.     }  
    65.   
    66. }  
    通过wait和notify机制来实现这两个线程的循环的有序性,能够保证子线程循环10次,主线程循环100次这样交替运行。

    运行结果很多,这里就不截图了!这里我们也是可以看到的,调用wait方法是会释放锁的,所以他会被用到很多,这个和之前的几个方法是不同的!


    注意的两点:

    第一:同步代码块中的锁和调用wait和notifiy方法的对象锁一定要是同一个。

    第二:wait和notify方法的调用一定要在同步代码块中,不然会报异常,可以自行测试一下。


    不要因为这样就结束了,这一篇还不是最终篇,等待下一篇吧!

    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    Spark2.3(三十六):根据appName验证某个app是否在运行
    Spark2.3(三十五)Spark Structured Streaming源代码剖析(从CSDN和Github中看到别人分析的源代码的文章值得收藏)
    Spark:实现行转列
    Spark2.3(三十四):Spark Structured Streaming之withWaterMark和windows窗口是否可以实现最近一小时统计
    Spark2.2(三十三):Spark Streaming和Spark Structured Streaming更新broadcast总结(一)
    Centos7:Failed to start LSB: Bring up/down networking
    CDH:cdh5环境搭建
    CDH:cdh5环境mkdir: Permission denied: user=root, access=WRITE, inode="/user":hdfs:hadoop:drwxr-xr-x
    Spark2.2+ES6.4.2(三十二):ES API之index的create/update/delete/open/close(创建index时设置setting,并创建index后根据avro模板动态设置index的mapping)
    Spark2.2+ES6.4.2(三十一):Spark下生成测试数据,并在Spark环境下使用BulkProcessor将测试数据入库到ES
  • 原文地址:https://www.cnblogs.com/pjdssswe/p/4696085.html
Copyright © 2020-2023  润新知