子线程循环10次,接着主线程循环100次,接着又回到子线程循环10次,接着再回到主线程循环100次,如此循环50次-004...

package com.loong.thread;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * 子循环10次,主循环100次,如此反复50次*/
public class ConditionTest7 {

    public static void main(String[] args) throws InterruptedException {
        MyService ms = new MyService();       
        new Thread(new Runnable() {        
            @Override
            public void run() {
                for(int i = 1; i<=50;i++){
                    ms.sub(i);
                }
            }
        }){}.start();
        
        Thread.sleep(1000); // 目的是让子线程先跑
        
        // main方法本身即为主线程
        for(int i = 1; i<=50;i++){
            ms.main(i);
        }
    }
    
    static class MyService{
        boolean beShouldSub = true;
        public synchronized void sub(int i){
            
            if(!beShouldSub){
                try {
                    this.wait();
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            for(int j =1;j<=10;j++){
                System.out.println("sub thread sequeue of " + j + "loop of " + i);
            }
            beShouldSub = false;
            this.notify();
        }        
        public synchronized void main(int i){
            if(beShouldSub){
                try {
                    this.wait();
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            for(int j =1;j<=20;j++){
                System.out.println("Main thread sequeue of " + j + "loop of " + i);
            }
            
            beShouldSub = true;
            this.notify();
        }        
    }
}
package com.loong.thread;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * 子循环10次,主循环100次,如此反复50次*/
public class ConditionTest6 {

    public static void main(String[] args) throws InterruptedException {
        MyService ms = new MyService();
        
        new Thread(new Runnable() {
            
            @Override
            public void run() {
                for(int i = 1; i<=50;i++){
                    ms.sub(i);
                }
            }
        }){}.start();
        
        Thread.sleep(1000); // 目的是让子线程先跑
        
        // main方法本身即为主线程
        for(int i = 1; i<=50;i++){
            ms.main(i);
        }

    }
    
    static class MyService{
        Lock lock = new ReentrantLock();
        Condition conditionSub = lock.newCondition();
        Condition conditionMain = lock.newCondition();
        boolean beShouldSub = true;
        
        public void sub(int i){
            try {
                lock.lock();
                while(!beShouldSub){
                    conditionSub.await();
                }
                for(int j =1;j<=10;j++){
                    System.out.println("sub thread sequeue of " + j + "loop of " + i);
                }
                beShouldSub = false;
                conditionMain.signal();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }finally{
                lock.unlock();                
            }
        }        
        public void main(int i){
            try {
                lock.lock();
                while(beShouldSub){
                    conditionMain.await();
                }
                for(int j =1;j<=20;j++){
                    System.out.println("Main thread sequeue of " + j + "loop of " + i);
                }
                beShouldSub = true;
                conditionSub.signal();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }finally{
                lock.unlock();                
            }
        }        
    }
}

 备注:原来做的笔记是错误的,就没有跑一下看效果吗?

转载于:https://www.cnblogs.com/ysloong/p/6370104.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值