【每日力扣Leetcode】1114-按序打印(多解法来深入理解python中的锁和阻塞)

本文介绍力扣题库1114题的多种解决方案,包括使用死循环、锁、Condition及队列等方法,确保在多线程环境下方法按指定顺序执行。

力扣题库1114,在单例模式的前提下,使得类中的3个方法按照指定顺序执行。

题目链接点这里

题目描述

我们提供了一个类:

public class Foo {
  public void first() { print("first"); }
  public void second() { print("second"); }
  public void third() { print("third"); }
}

三个不同的线程将会共用一个 Foo 实例。

  • 线程 A 将会调用 first() 方法
  • 线程 B 将会调用 second() 方法
  • 线程 C 将会调用 third() 方法

请设计修改程序,以确保 second() 方法在 first() 方法之后被执行,third() 方法在 second() 方法之后被执行。

解题思路

看到这道题,三个线程公用一个实例,首先想到的是单例模式。于是想着在类里面设置一个变量,这里因为题目指定了三个线程公用同一个实例,所以类变量还是实例变量不重要。然后3个方法的执行对应变量的3个不同的值。但是单单有变量的判断还不够,因为子线程没有阻塞,所以3个线程同时在跑,最终永远只有first()方法被执行

所以用如下死循环的思路加入阻塞。

变量的初始值为1,方法first()可以直接执行,执行完毕将变量值改为2;方法second()执行前先做一个死循环,退出条件是变量值为2;方法third()类似,不过变量值需要为3。

初始答案

class Foo:
    def __init__(self):
        self.temp = 1

    def first(self, printFirst: 'Callable[[], None]') -> None:
        # printFirst() outputs "first". Do not change or remove this line.
        printFirst()
        self.temp = 2


    def second(self, printSecond: 'Callable[[], None]') -> None:
        while self.temp != 2:
            pass 
        # printSecond() outputs "second". Do not change or remove this line.
        printSecond()
        self.temp = 3


    def third(self, printThird: 'Callable[[], None]') -> None:
        while self.temp != 3:
            
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值