1

我在今天的采访中得到了这个问题。

class BankAccount {
    private int money;

    public synchronized void deposite(int sum) {
        money += sum;
    }

    public synchronized void withdraw(int sum) {
        money -= sum;
    }

    public synchronized int getMoney() {
        return money;
    }
}

class accountManager {
    public void transfer(BankAccount a, BankAccount b, int money) {      
    }
}

所以我需要编写 transfer() 方法,所以它将是线程安全的,并且帐户余额应该> = 0。

public void transfer(BankAccount a, BankAccount b, int money) {
    synchronized ( a ) {
        synchronized ( b ) {
            int temp = a.getMoney() - money;
            if (temp >= 0) {
                a.withdraw(temp);
                b.add(temp);
            }
        }
    }
}

我写了这个,但是当我们同时从 a 转移到 b 和从 b 转移到 a 时,它会产生死锁。所以第二个问题是,如何解决死锁?

4

1 回答 1

5

您必须以相同的顺序锁定对象,否则您将陷入死锁。

顺便说一句:鉴于锁比执行的操作要昂贵得多,最好使用全局锁或只使用一个线程。

于 2013-08-28T12:13:31.460 回答