当前位置: 移动技术网 > IT编程>开发语言>Java > java 中线程等待与通知的实现

java 中线程等待与通知的实现

2019年07月19日  | 移动技术网IT编程  | 我要评论

java 中线程等待与通知的实现

前言:

关于等待/通知,要记住的关键点是:

必须从同步环境内调用wait()、notify()、notifyall()方法。线程不能调用对象上等待或通知的方法,除非它拥有那个对象的锁。

wait()、notify()、notifyall()都是object的实例方法。与每个对象具有锁一样,每个对象可以有一个线程列表,他们等待来自该信号(通知)。线程通过执行对象上的wait()方法获得这个等待列表。从那时候起,它不再执行任何其他指令,直到调用对象的notify()方法为止。如果多个线程在同一个对象上等待,则将只选择一个线程(不保证以何种顺序)继续执行。如果没有线程等待,则不采取任何特殊操作。

 示例代码:

package threadwait;

public class threada extends thread{

  public int num = 0;

  public void run(){

    synchronized (this){//在此类对象上实现同步,this指代当前对象

      for(int i = 0 ; i < 3 ; ++i)

       this.num+=i;

      notifyall();//通知所有在这个对象上等待的线程开始执行,在这里就是通知testnotify主线程开始执行

    }

  }

  public int getnum(){

    return this.num;

  }

}

package threadwait;

 

public class testnotify{

  public static void main(string args[]){

    threada threada = new threada();

    threada.start();//threada线程有执行的资格,但是还没有开始执行

    synchronized(threada){

      try{

       threada.wait();//主线程等待threada线程执行结束才开始执行

       //而且只有获得了当前threada对象的锁之后才能执行wait,就是说在同步域内才可以执行wait,执行wait后放弃对象锁

      }catch(interruptedexception e){

       e.printstacktrace();

      }

    }

    system.out.println(threada.getnum());

  }

}

同步可以是在class级别上的,synchronized(a.class),也可以是在对象级别上的synchronized(this),可以是静态同步方法,static synchronized ,静态同步方法是在class级别上的,非静态同步方法是在类对象级别上的,一个类对象只有一个锁,只有获得了该锁才可以对他执行wait操作,后释放掉该锁。

更进一步的实例代码如下:

package threadwait;

 

public class threada extends thread{

  public int num = 0;

  public void run(){

    synchronized (this){//在此类对象上实现同步,this指代当前对象

      for(int i = 0 ; i < 3 ; ++i)

       this.num+=i;

      try{

       thread.sleep(500);//如果threadb的三个示例线程在还没有进入等待状态之前就受到了notifyall的信号

       //那将会发生严重后果,因为调用notifyall的线程只可以调用一次notifyall,那造成等待的线程将永远等待下去

       //所以在此处让它睡一小会,让其他线程有时间进入等待状态。

       //不然会收到

      }catch(interruptedexception e){

       e.printstacktrace();

      }

      notifyall();//通知所有在这个对象上等待的线程开始执行,在这里就是通知testnotify主线程开始执行

    }

//   notifyall();

  }

  public int getnum(){

    return this.num;

  }

}

package threadwait;

 

public class threadb extends thread{

  private threada threada;

  public threadb(threada ta){

    this.threada = ta;

  }

  public void run(){

    system.out.println(thread.currentthread().getname()+" is waitting.");

    synchronized(threada){

      try{

       threada.wait();

      }catch(interruptedexception e){

       e.printstacktrace();

      }

      system.out.println(thread.currentthread().getname()+" "+this.threada.getnum());

    }

   

  }

}

package threadwait;

 

public class testnotify{

  public static void main(string args[]){

    threada threada = new threada();

    new threadb(threada).start();

    new threadb(threada).start();

    new threadb(threada).start();

    threada.start();

  }

}

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网