Sobes.tech
Back to questions
Senior
5

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

Companies where asked
ТБанк

Answer from AI

sobes.tech AI

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

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

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

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

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