Java Object notify() 方法



描述

Java Object notify() 方法唤醒正在等待此对象监视器的单个线程。如果多个线程正在等待此对象,则选择其中一个线程唤醒。选择是任意的,并由实现决定。线程通过调用其中一个 wait 方法来等待对象的监视器。

此方法只能由拥有此对象监视器的线程调用。线程可以通过三种方式之一成为对象监视器的拥有者:

  • 通过执行该对象的同步实例方法。

  • 通过执行同步语句的主体,该语句与对象同步。

  • 对于 Class 类型的对象,通过执行该类的同步静态方法。

一次只有一个线程可以拥有对象的监视器。

声明

以下是java.lang.Object.notify()方法的声明

public final void notify()

参数

返回值

此方法不返回值。

异常

IllegalMonitorStateException - 如果当前线程不是此对象监视器的拥有者。

唤醒等待线程示例

下面的示例展示了 java.lang.Object.notify() 方法的用法。在这个程序中,我们创建了 ObjectDemo 类,它具有 addElement 和 removeElement 方法。这些方法本质上是同步的,在添加元素时,我们使用 notify() 方法唤醒等待线程以访问对象的监视器。在主方法中,我们有两个可运行实例,一个用于删除元素,另一个用于添加元素。一旦线程创建并启动,就会调用 addElement() 和 removeElement() 方法。

package com.tutorialspoint;

import java.util.Collections;
import java.util.LinkedList;
import java.util.List;

public class ObjectDemo extends Object {

   private List synchedList;

   public ObjectDemo() {
      // create a new synchronized list to be used
      synchedList = Collections.synchronizedList(new LinkedList());
   }

   // method used to remove an element from the list
   public String removeElement() throws InterruptedException {
      synchronized (synchedList) {

         // while the list is empty, wait
         while (synchedList.isEmpty()) {
            System.out.println("List is empty...");
            synchedList.wait();
            System.out.println("Waiting...");
         }
         String element = (String) synchedList.remove(0);

         return element;
      }
   }

   // method to add an element in the list
   public void addElement(String element) {
      System.out.println("Opening...");
      synchronized (synchedList) {

         // add an element and notify all that an element exists
         synchedList.add(element);
         System.out.println("New Element:'" + element + "'");

         synchedList.notify();
         System.out.println("notify called!");
      }
      System.out.println("Closing...");
   }

   public static void main(String[] args) {
      final ObjectDemo demo = new ObjectDemo();

      Runnable runA = new Runnable() {

         public void run() {
            try {
               String item = demo.removeElement();
               System.out.println("" + item);
            } catch (InterruptedException ix) {
               System.out.println("Interrupted Exception!");
            } catch (Exception x) {
               System.out.println("Exception thrown.");
            }
         }
      };

      Runnable runB = new Runnable() {

         // run adds an element in the list and starts the loop
         public void run() {
            demo.addElement("Hello!");
         }
      };

      try {
         Thread threadA1 = new Thread(runA, "A");
         threadA1.start();

         Thread.sleep(500);

         Thread threadA2 = new Thread(runA, "B");
         threadA2.start();

         Thread.sleep(500);

         Thread threadB = new Thread(runB, "C");
         threadB.start();

         Thread.sleep(1000);

         threadA1.interrupt();
         threadA2.interrupt();
      } catch (InterruptedException x) {
      }
   }
}

输出

让我们编译并运行上述程序,这将产生以下结果:

List is empty...
List is empty...
Opening...
New Element:'Hello!'
notify called!
Closing...
Waiting...
Hello!
Interrupted Exception!
java_lang_object.htm
广告