美文网首页
多线程 按序打印

多线程 按序打印

作者: 天堂鸟6 | 来源:发表于2020-08-06 19:31 被阅读0次

    https://leetcode-cn.com/problems/print-in-order/

    我们提供了一个类:

    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"。

    注意:

    尽管输入中的数字似乎暗示了顺序,但是我们并不保证线程在操作系统中的调度顺序。

    你看到的输入格式主要是为了确保测试的全面性。

    import java.util.concurrent.Semaphore;
    class Foo {
        public Semaphore seam_first_two = new Semaphore(0);
        
        public Semaphore seam_two_second = new Semaphore(0);
        
        public Foo() {
            
        }
    
        public void first(Runnable printFirst) throws InterruptedException {
            printFirst.run();
            seam_first_two.release();
        }
    
        public void second(Runnable printSecond) throws InterruptedException {
            seam_first_two.acquire();
            printSecond.run();
            seam_two_second.release();
        }
    
        public void third(Runnable printThird) throws InterruptedException {
            seam_two_second.acquire();
            printThird.run();
        }
    }
    

    相关文章

      网友评论

          本文标题:多线程 按序打印

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