view asyncio_threads/bank_question/README.md @ 68:70ca1d99f3fd

Mimicing what tsoding did for his video. Kinda cool.
author June Park <parkjune1995@gmail.com>
date Thu, 25 Dec 2025 20:03:51 -0800
parents 46daba6e3cf4
children
line wrap: on
line source

# Bank Account

You are given a simplified multi-threaded “bank account” implementation used by one of our infrastructure teams. The current code processes deposits concurrently but produces incorrect results.

```
class BankAccount:
    def __init__(self, balance):
        self.balance = balance

    def deposit(self, amount):
        new_balance = self.balance + amount  # read
        time.sleep(0.1)                      # simulate delay
        self.balance = new_balance           # write

account = BankAccount(0)

with ThreadPoolExecutor(max_workers=2) as executor:
    futures = [
        executor.submit(account.deposit, 500),
        executor.submit(account.deposit, 700),
    ]
```

Task

Identify the concurrency bugs in the implementation.

Explain why these bugs occur.

Fix the implementation without modifying the existing BankAccount class directly.

You may use subclassing (Python) or embedding (Go-style composition), depending on the language you choose.

Ensure your solution is thread-safe and produces the correct final balance (1200).