用两个线程一个输出字母一个输出数字,交替输出:1A2B3C4D...26Z(三种方法实现)

/**
 * 用两个线程,一个输出字母,一个输出数字,交替输出:1A2B3C4D...26Z
 * @author CP-CUI
 *
 */
public class TestThread {
	
	
	static Thread t1 = null,t2 = null;
	
	public static void main(String[] args) {
		char[] num = "12345678".toCharArray();
		char[] ch = "ABCDEFGH".toCharArray();
		useLockCondition(num, ch);
	}
	
	/**
	 * 方法1:使用LockSupport的park方法
	 * @param num
	 * @param ch
	 */
	private static void useLockSupport(char[] num,char[] ch) {
		
		t1 = new Thread(()->{
			for (char c : num) {
				System.out.print(c);
				// 叫醒t2
				LockSupport.unpark(t2);
				// t1阻塞
				LockSupport.park();
			}
		} ,"t1");
		
		
		t2 = new Thread(()->{
			for (char c : ch) {
				// t2阻塞
				LockSupport.park();
				System.out.print(c);
				// 叫醒t1
				LockSupport.unpark(t1);
			}
		} ,"t2");
		
		t1.start();
		t2.start();
	}
	
	/**
	 * 方法2:使用Synchronized的wait和notify方法
	 * @param num
	 * @param ch
	 */
	private static void useWaitNotify(char[] num,char[] ch) {
		
		// 创建一个锁对象
		final Object o = new Object();
		
		new Thread(() ->{
			synchronized (o) {
				for (char c : ch) {
					System.out.print(c);
					try {
						o.notify();
						// 自己让出锁
						o.wait();
					} catch (InterruptedException e) {
						e.printStackTrace();
					} 
				}
				// 必须加,否则程序无法停止
				o.notify();
			}
			
		}, "t1").start(); 
		
		
		new Thread(() ->{
			synchronized (o) {
				for (char c : num) {
					System.out.print(c);
					try {
						o.notify();
						// 自己让出锁
						o.wait();
					} catch (InterruptedException e) {
						e.printStackTrace();
					} 
				}
				// 必须加,否则程序无法停止
				o.notify();
			}
			
		}, "t2").start(); 
	}
	
	/**
	 * 方法3:使用ReentrantLock的lockCondition
	 * @param num
	 * @param ch
	 */
	private static void useLockCondition(char[] num,char[] ch) {
		
		Lock lock = new ReentrantLock();
		/**
		 *  condition是个队列,一个condition是一个队列,可以用来解决生产者消费者问题,
		 *  将生产者和消费者分别放入两个condition也就是两个队列里,这样就可以分别叫醒生产者和消费者,不用同时把他们叫醒了。
		 *  而平常的synchronized只有一个队列,生产者和消费者全都放在一个队列里了
		 */
		 
		Condition conditionT1 = lock.newCondition();
		Condition conditionT2 = lock.newCondition();
		
		new Thread(() ->{
			try {
				lock.lock();
				for (char c : ch) {
					System.out.print(c);
					// 叫醒t2
					conditionT2.signal();
					// t1等待
					conditionT1.await();
				}
				conditionT2.signal();
			} catch (Exception e) {
				e.printStackTrace();
			} finally {
				lock.unlock();
			}
		}, "t1").start();  
		
		new Thread(() ->{
			try {
				lock.lock();
				for (char c : num) {
					System.out.print(c);
					// 叫醒t1
					conditionT1.signal();
					// t2等待
					conditionT2.await();
				}
				conditionT1.signal();
			} catch (Exception e) {
				e.printStackTrace();
			} finally {
				lock.unlock();
			}
		}, "t2").start();  
	}
}

输出结果

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值