线程面试手撕代码总结

1.交替打印ABC n次(Synchronized+wait/notify)

//synchronized+wait/notify
    private int num;
    private static  final Object LOCK=new Object();
    int n=10;
    private  void printABC(String name,int targetNum){
        for(int i=0;i<n;i++){
        synchronized (LOCK){
            while(num%3!=targetNum){
                try{
                    LOCK.wait();
                }catch(InterruptedException e){
                    e.printStackTrace();
                }
            }
            num++;
            System.out.println(name);
            LOCK.notifyAll();
        }}
    }

    public static void main(String[] args) {
        occur occur=new occur();
        new Thread(()->{
          occur.printABC("A",0);
        }).start();
        new Thread(()->{
            occur.printABC("B",1);
        }).start();
        new Thread(()->{
            occur.printABC("C",2);
        }).start();
    }

2.交替打印ABC n次,利用join()

 static class printABC implements Runnable{
        private Thread beforeThread;
        public printABC(Thread beforeThread){
            this.beforeThread=beforeThread;
        }
        @Override
        public void run() {
            if(beforeThread!=null){
                try {
                    beforeThread.join();
                    System.out.println(Thread.currentThread().getName());
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

            }else{
                System.out.println(Thread.currentThread().getName());
            }
        }
    }

    public static void main(String[] args) {
        int i=0;
        while(i<10){
            Thread t1=new Thread(new printABC(null),"A");
            Thread t2=new Thread(new printABC(t1),"B");
            Thread t3=new Thread(new printABC(t2),"C");
            t1.start();
            t2.start();
            t3.start();
            i++;
        }
    }

3.交替打印ABC n次,利用 Lock+Condition

private int num;
    private static Lock lock=new ReentrantLock();
    private static Condition c1= lock.newCondition();
    private static Condition c2= lock.newCondition();
    private static Condition c3= lock.newCondition();

    private void printABC(String name,int targetNum,Condition currentThread,Condition nextThread){
        for(int i=0;i<10;i++){
            lock.lock();
            try{
                while(num%3!=targetNum){
                    currentThread.await();
                }
                num++;
                System.out.println(name);
                nextThread.signal();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }finally {
                lock.unlock();
            }
        }
    }

    public static void main(String[] args) {
        occur occur=new occur();
        new Thread(()->{
            occur.printABC("A",0,c1,c2);
        }).start();
        new Thread(()->{
            occur.printABC("B",1,c2,c3);
        }).start();
        new Thread(()->{
            occur.printABC("C",2,c3,c1);
        }).start();
    }

4.交替打印ABC n次,利用Semaphore

 private static Semaphore c1=new Semaphore(1);
    private static Semaphore c2=new Semaphore(0);
    private static Semaphore c3=new Semaphore(0);

    private void printABC(String name,int targetNum,Semaphore currentThread,Semaphore nextThread){
        for(int i=0;i<10;i++){
            try{
                currentThread.acquire();
                System.out.println(name);
                nextThread.release();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    public static void main(String[] args) {
        occur occur=new occur();
        new Thread(()->{
            occur.printABC("A",0,c1,c2);
        }).start();
        new Thread(()->{
            occur.printABC("B",1,c2,c3);
        }).start();
        new Thread(()->{
            occur.printABC("C",2,c3,c1);
        }).start();
    }

5.交替打印奇偶数

 private static  final Object monitor=new Object();
    private volatile int count;
    public occur(int initCount){
        this.count=initCount;}
    private void printOddEven(){
       synchronized (monitor){
           while(count<50){
               System.out.println(Thread.currentThread().getName()+":");
               System.out.println(++count);
               monitor.notifyAll();
               try {
                   monitor.wait();
               } catch (InterruptedException e) {
                   e.printStackTrace();
               }
           }
           monitor.notifyAll();
        }
    }


    public static void main(String[] args) throws InterruptedException {
     occur occur=new occur(0);
     new Thread(occur::printOddEven,"odd").start();
     Thread.sleep(10);
     new Thread(occur::printOddEven,"even").start();
    }

6.3个线程交替打印10以内的数

  private int num;
    private static final Object monitor=new Object();
    private int Maxnum=10;
    private void printOddEven(String name,int tarNum){
           while(true){
               synchronized (monitor){
                    if(num>=Maxnum){
                       break;
                   }
                   num++;
                   System.out.println(Thread.currentThread().getName()+":"+num);
                   monitor.notifyAll();
               while(num%3!=tarNum){
                   if(num>=Maxnum){
                       break;
                   }
                   try{
                       monitor.wait();
                   }catch (InterruptedException e){
                       e.printStackTrace();
                   }
               }
               
        }}
    }


    public static void main(String[] args) throws InterruptedException {
     occur occur=new occur();
     new Thread(()->{
         occur.printOddEven("thread1",0);
     },"thread1").start();
        new Thread(()->{
            occur.printOddEven("thread2",1);
        },"thread2").start();
        new Thread(()->{
            occur.printOddEven("thread3",2);
        },"thread3").start();
    }

7.轮流打印数字、字符

   static class PrintThread implements Runnable {
        private static final Object lock = new Object();
        private static int num = 1;
        private static char ch = 'A';
        private final boolean isNumberThread;

        public PrintThread(boolean isNumberThread) {
            this.isNumberThread = isNumberThread;
        }

        @Override
        public void run() {
            while (true) {
                synchronized (lock) {
                    if (isNumberThread) {
                        // 如果是数字线程,则打印数字并增加num变量
                        if (num <= 26) {
                            System.out.print(num + " ");
                            num++;
                        } else {
                            break;
                        }
                    } else {
                        // 如果是字符线程,则打印字符并增加ch变量
                        if (ch <= 'Z') {
                            System.out.print(ch + " ");
                            ch++;
                        } else {
                            break;
                        }
                    }
                    // 通知另一个线程运行
                    lock.notify();

                    try {
                        // 当前线程暂停,等待另一个线程打印
                        if (num <= 26 || ch <= 'Z') {
                            lock.wait();

                        } else {
                            break;
                        }
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }

                }
            }
        }
    }

        public static void main(String[] args) {
            Thread t1 = new Thread(new PrintThread(true)); // 数字线程
            Thread t2 = new Thread(new PrintThread(false)); // 字符线程
            t1.start();
            t2.start();
        }

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吃橘子的Crow

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值