文章标题

  1. 使用阻塞队列实现: 子线程循环10次,接着主线程循环100,接着又回到子线程循环10次,接着再回到主线程又循环100次,如此循环50次
package BlockQueue;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;


public class BlockingQueueTest {

    public static void main(String[] args) throws InterruptedException {
         final Business bus=new Business();
        // 子线程循环
        Thread sub=new Thread(new Runnable(){
            @Override
            public void run() {
            for(int n=0;n<50;n++){
                try {
                    bus.sub(n);
                } catch (InterruptedException e1) {
                    e1.printStackTrace();
                }   
                try {
                    Thread.sleep(50);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
              }
            }

        });
        sub.start();

        // main函数本身就是一个主线程
        for(int n=0;n<50;n++){
        bus.main(n);
        try {
            Thread.sleep(50);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        }
    }

static  class Business{ 
// 使用阻塞队列实现
    // 先往阻塞队列2中放入一个数据。那么线程会先执行子线程,因为主线程阻塞了;只有子线程执行完b2.take之后,主线程才能put
    BlockingQueue<Integer> b1=new ArrayBlockingQueue<Integer>(1);
    BlockingQueue<Integer> b2=new ArrayBlockingQueue<Integer>(1);
    {
        // 先往队列2中放入一个数据
        try {
            System.out.println("构造函数");
            b2.put(1);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }


    // 子线程先执行,因为b2刚开始阻塞了
        public  void sub(int n) throws InterruptedException{
        b1.put(1);
             for(int i=0;i<10;i++){
                    System.out.println("sub 循环第"+i+"次,loop"+n); 
        }

             b2.take();
        }

        //主线程业务类
        public  void main(int n) throws InterruptedException {
        b2.put(1);
            for(int i=0;i<10;i++){
                System.out.println("main 循环第"+i+"次 ,loop "+n);
            }
            b1.take();

        }
    }
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值