java多线程循环打印A,B,C

我最近在准备面试,突然想起来大概二年前的汽车之家面试的一道题,题目是java多线程循环打印A,B,C,14年这道题还是不会,这两年过去了,又在传统行业混了二年,水平其实并没有长得很快,毕竟感觉自己用的太少了平时,过不久老不用就忘记了。现在来把这道当时欠的债还清吧。。

写完后,顺手百度了一下,对比一下,结果发现这个搜索词还比较少,只有一个百度知道里的提问,截图:


我只想说真是逗比啊,本来是想回复的,找了半天没找到回复按钮,可能时间太久的缘故吧。。。线程刚上来就休眠一秒钟,我无法理解。

其实这道题就是一个生产者消费者的问题变种,在生产者消费者中,简单的说就是一个线程生产一个,另一个线程消费一个,只涉及两方, 完全可以写一个循环打印A,B的,

而生产者消费者这种问题,我现在知道的有3种,1、使用obj.notify和wait方法进行协作;2、使用重入锁,配合Condition进行;3、使用阻塞队列完成;第三种是最简便的,因为你都不需要上锁了,阻塞队列就阻塞在哪里了;

而这个题目涉及了3方,我个人认为第1,3种无法实现,当然我是这么认为的,重入锁的Condition可以定向唤醒一些等待的线程,更方便,废话不多说了,直接上代码:

public class Print {
	ReentrantLock lock = new ReentrantLock();
	Condition ac = lock.newCondition();
	Condition bc = lock.newCondition();
	Condition cc = lock.newCondition();
	public static void main(String[] args) throws InterruptedException{
		Print p = new Print();
		A a = p.new A();
		B b = p.new B();
		C c = p.new C();
		
		a.start();
		b.start();
		c.start();
		
	}
	
	class A extends Thread{
		@Override
		public void run(){
			while(true){
				lock.lock();
				try{
					
					System.out.print("A,");
					bc.signal();
					ac.await();
				}catch(Exception e){
					e.printStackTrace();
				}
				
				lock.unlock();
			}
		}
	}
	
	class B extends Thread{
		public void run(){
			while(true){
				lock.lock();
				try{
					
					System.out.print("B,");
					cc.signal();
					bc.await();
				}catch(Exception e){
					e.printStackTrace();
				}
				
				lock.unlock();
			}
		}
	}
	
	class C extends Thread{
		public void run(){
			while(true){
				lock.lock();
				try{
					
					System.out.println("C");
					ac.signal();
					cc.await();
				}catch(Exception e){
					e.printStackTrace();
				}
				
				lock.unlock();
			}
		}
	}
}
结果如下:



你可能感兴趣的:(java)