Sobes.tech
Назад к вопросам
Senior
4

Как исправить deadlock в задаче с Wallets? Можно ли использовать атомики?

Компании, где спрашивали
ТБанк

Ответ от нейросети

sobes.tech AI

Deadlock в задаче с Wallets обычно возникает при одновременном захвате нескольких блокировок в разном порядке, например, при переводе средств между кошельками. Чтобы исправить deadlock, нужно обеспечить согласованный порядок захвата блокировок. Например, всегда блокировать кошельки по возрастанию их ID.

Использование атомарных операций (атомиков) подходит, если операции над балансом можно свести к простым атомарным инкрементам/декрементам без необходимости блокировать несколько ресурсов одновременно. Однако в случае перевода между двумя кошельками атомики не помогут, так как нужно обеспечить согласованность между двумя счетами.

Пример решения с упорядоченным захватом блокировок:

synchronized (wallet1.getId() < wallet2.getId() ? wallet1 : wallet2) {
    synchronized (wallet1.getId() < wallet2.getId() ? wallet2 : wallet1) {
        // перевод средств
    }
}

Таким образом, deadlock устраняется за счет фиксированного порядка захвата блокировок.