zoukankan      html  css  js  c++  java
  • java多线程之wait和notify

    多线程中的通信是非常重要的概念,线程直接实现通信就可以并发完成很多复杂工作。

    java在Object类中就设计了wait()和notify()两个方法,以解决这个问题。

    1.释义:

    wait()方法将当前线程暂停,置于“预执行队列”中,而notify()则用于通知一个在wait等待中的线程,可以继续执行了

    2.wait()和notify()的使用条件:

    wait()和notify()必须置于同步方法和同步代码块中使用,即在调用前,线程必须获得该对象的对象级别锁。否则会抛出异常

    3.线程执行到wait()时,直接释放锁,处于等待状态;

    public class WaitService {
        public void testMethod(Object lock) {
            try {
                synchronized (lock) {
                    System.out.println("wait begin");
                    lock.wait();
                    System.out.println("wait end");
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
    
    public class WaitThread1 extends Thread {
        private Object lock;
    
        public WaitThread1(Object lock) {
            this.lock = lock;
        }
    
        @Override
        public void run() {
            WaitService service = new WaitService();
            service.testMethod(lock);
        }
    }
    
    public class WaitThread2 extends Thread {
        private Object lock;
    
        public WaitThread2(Object lock) {
            this.lock = lock;
        }
    
        @Override
        public void run() {
            WaitService service = new WaitService();
            service.testMethod(lock);
        }
    }
    
    public class WaitTest {
        public static void main(String[] args) {
            Object lock=new Object();
            WaitThread1 t1=new WaitThread1(lock);
            WaitThread2 t2 = new WaitThread2(lock);
            t1.start();
            t2.start();
        }
    }

    执行结果:

    wait begin
    wait begin

    4.线程执行notify时,当前线程并不马上释放锁,wait状态的线程也不会马上获得锁,要执行notify方法的程序执行完,退出syncronized代码块后,才释放锁。

    public class NotifyService {
        public void testMethod(Object lock){
            try {
                synchronized (lock){
                    System.out.println("wait  begin");
                    lock.wait();
                    System.out.println("wait  end");
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    
        public void notifyMethod(Object lock){
            try {
                synchronized (lock) {
                    System.out.println("begin nofity ");
                    Thread.sleep(1000);
                    lock.notify();
                    System.out.println("end nofity ");
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
    
    public class NotifyThreadA extends Thread{
        private Object lock;
    
        public NotifyThreadA(Object lock) {
            this.lock = lock;
        }
    
        @Override
        public void run() {
            NotifyService service=new NotifyService();
            service.testMethod(lock);
        }
    }
    
    public class NotifyThreadB extends Thread {
        private Object lock;
    
        public NotifyThreadB(Object lock) {
            this.lock = lock;
        }
    
        @Override
        public void run() {
            NotifyService service=new NotifyService();
            service.notifyMethod(lock);
        }
    }
    
    public class NotifyTest {
        public static void main(String[] args) {
            Object lock=new Object();
            NotifyThreadA a = new NotifyThreadA(lock);
            a.start();
            NotifyThreadB b = new NotifyThreadB(lock);
            b.start();
        }
    }

    输出:

    wait  begin
    begin nofity 
    end nofity 
    wait  end
  • 相关阅读:
    Dubbo
    支持微服务架构落地的Java框架
    thinkphp6的主要特性
    thinkphp5的主要特性
    RPC
    HTTP1.0 HTTP1.1 HTTP2.0 主要特性对比
    RabbitMQ 生产环境配置详解
    分布式AKF拆分原则
    通过Hystrix了解分布式接口级的高可用
    Python中使用grpc与consul
  • 原文地址:https://www.cnblogs.com/wangbin2188/p/9290575.html
Copyright © 2011-2022 走看看