多线程循环打印输出问题(三)

//争抢的锁资源
	public static Lock lock =new ReentrantLock();
	//控制线程挂起和执行
	public static Condition cond =lock.newCondition();
	//保证线程优先执行
	public volatile static boolean flag =true;
	public static void main(String[] args) {
		new Thread(new Runnable(){
			@Override
			public void run() {
				lock.lock();
				flag=false;
				for(int i=0;i<5;i++){
					System.out.println("a");
					cond.signalAll();//唤醒挂起的线程
					try {
						cond.await();//自身挂起
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
				cond.signalAll();
				lock.unlock();
				
			}
		}).start();
		new Thread(new Runnable(){
			@Override
			public void run() {
				lock.lock();
				if(flag){
					try {
						cond.await();
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
				for(int i=0;i<5;i++){
					System.out.println("b");
					cond.signalAll();
					try {
						cond.await();
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}				
				lock.unlock();				
			}
		}).start();
		
	}

和synchronized思路一样,都是控制线程的挂起和唤醒,还有注意对哪个线程优先的控制,后面想想volatile关键字,其实没有起到作用,加上锁的区域就保证了可见性,不需要用volatile了。


你可能感兴趣的:(多线程,ReentrantLock)