线程间使用wait和notify通信

    xiaoxiao2021-04-15  40

    package com.线程间通信; import java.util.ArrayList; import java.util.List; public class Thread2Thread { //声明一个 实例变量 private volatile static List<String> list = new ArrayList<String>(); public void add(){ list.add("1"); } public int size(){ return list.size(); } public static void main(String [] args){ final Thread2Thread t = new Thread2Thread(); final Object lock = new Object(); //线程1 往list中加数据 Thread t1 = new Thread(new Runnable() { public void run() { try { synchronized(lock){ for (int i =0; i<10; i++){ t.add(); System.out.println("当前线程"+Thread.currentThread().getName()+":添加了一个数据。。"); Thread.sleep(500); if(list.size() == 5){ //发送通知 但是notifi方法不释放锁 锁被释放是在10次循环结束后释放(即synchronized块结束后) System.out.println("已经发出通知。。"); lock.notify(); } } } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }, "t1"); //线程2 当list数组中有5个元素时 就打印一句话 Thread t2 = new Thread(new Runnable() { public void run() { synchronized(lock){ try { if(t.size() != 5){ //wait释放锁 此时的线程就在这儿阻塞 所以下面的print语句没有打印 相反的t1线程获得了锁 也发出了通知 //这时 线程2就从阻塞状态中到active状态 于是就有了下面的打印 线程阻塞时 就让出了cpu,效率也提高了 lock.wait(); } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } //打印一句话 System.out.println("当前线程"+Thread.currentThread().getName()+":接收到通知。。"); throw new RuntimeException(); } } }, "t2"); t2.start(); t1.start(); } }
    转载请注明原文地址: https://ju.6miu.com/read-671157.html

    最新回复(0)