美文网首页
1111.4 按序打印

1111.4 按序打印

作者: 她和她的喵真好看 | 来源:发表于2019-10-16 11:06 被阅读0次

    题目

    我们提供了一个类:
    
    public class Foo {
      public void one() { print("one"); }
      public void two() { print("two"); }
      public void three() { print("three"); }
    }
    
    三个不同的线程将会共用一个 Foo 实例。
    
    线程 A 将会调用 one() 方法
    线程 B 将会调用 two() 方法
    线程 C 将会调用 three() 方法
    请设计修改程序,以确保 two() 方法在 one() 方法之后被执行,three() 方法在 two() 方法之后被执行。
    
     
    
    示例 1:
    
    输入: [1,2,3]
    输出: "onetwothree"
    解释: 
    有三个线程会被异步启动。
    输入 [1,2,3] 表示线程 A 将会调用 one() 方法,线程 B 将会调用 two() 方法,线程 C 将会调用 three() 方法。
    正确的输出是 "onetwothree"。
    示例 2:
    
    输入: [1,3,2]
    输出: "onetwothree"
    解释: 
    输入 [1,3,2] 表示线程 A 将会调用 one() 方法,线程 B 将会调用 three() 方法,线程 C 将会调用 two() 方法。
    正确的输出是 "onetwothree"。
    
    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/print-in-order
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
    

    解法 CountDownLatch

    1. 代码实现
    import java.util.concurrent.CountDownLatch;
    
    
    class Foo {
        
        private static final int threadCount = 1;
        private CountDownLatch secondLatch = new CountDownLatch(threadCount);
        private CountDownLatch thirdLatch = new CountDownLatch(threadCount);
        
        public Foo() {
            
        }
    
        public void first(Runnable printFirst) throws InterruptedException {
            
            // printFirst.run() outputs "first". Do not change or remove this line.
            printFirst.run();
            secondLatch.countDown();
        }
    
        public void second(Runnable printSecond) throws InterruptedException {
            
            // printSecond.run() outputs "second". Do not change or remove this line.
            secondLatch.await();
            printSecond.run();
            thirdLatch.countDown();
        }
    
        public void third(Runnable printThird) throws InterruptedException {
            thirdLatch.await();
            // printThird.run() outputs "third". Do not change or remove this line.
            printThird.run();
        }
    }
    
    1. [CountDownLatch 解析](https://www.jianshu.com/writer#/notebooks/40148237/notes/54972805

    相关文章

      网友评论

          本文标题:1111.4 按序打印

          本文链接:https://www.haomeiwen.com/subject/hnvlmctx.html