经典面试题-线程间的通信问题(各种解法)

本文探讨了线程间通信的问题,详细介绍了如何使用LockSupport、CAS、AtomicInteger、BlockQueue、PipedStream以及Wait/Notify和LockCondition等方法实现线程交替输出数字和字母,例如1A2B3C4D5E6F...,为Java后端面试提供了经典案例。
摘要由CSDN通过智能技术生成
问题

两个线程,一个输出字母,一个输出数字,交替出现比如:1A2B3C4D5E6F…

实例图

代码实战
  • LockSupport方式

    public class LockSupportMethod {
         
        
        static   Thread t1 = null;
        static  Thread t2 = null;
    
        public static void main(String[] args) {
         
            char[] cI = "123456".toCharArray();
            char[] aC = "ABCDEF".toCharArray();
    
            t1 = new Thread(() -> {
         
                for (char i : cI) {
         
                    System.out.printf(String.valueOf(i));
                    LockSupport.unpark(t2);
                    LockSupport.park();
                }
            }, "t1");
    
            t2 = new Thread(() -> {
         
                for (char a : aC) {
         
                    LockSupport.park();
                    System.out.printf(String.valueOf(a));
                    LockSupport.unpark(t1);
                }
            }, "t2");
    
            t1.start();
            t2.start();
    
        }
    
    }
    
  • Cas模式实现

    public class CasMethod {
         
    
        enum Status {
         T1, T2}
    
        volatile static Status status = Status.T1;
    
        public static void main(String[] args) {
         
    
            char[] cI = "123456".toCharArray();
            char[] aC = "ABCDEF".toCharArray();
    
            new Thread(() -> {
         
    
                for (char i : cI) {
         
                    while (!Status.T1.equals(status)) {
         
                    }
                    System.out.printf(String.valueOf(i));
                    status = Status.T2;
                }
            }, "t1").start();
    
            new Thread(() -> {
         
                for (char a : aC) {
         
                    while (!Status.T2.equals(status)) {
         
                    }
                    Syste
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值