геттер и сеттер TokenValue каким-нибудь ReaderWriterLockSlim, чтобы никаких проблем с многопоточностью не было?
https://gist.github.com/ChXIII/f1b68f10273f55edd2a3d9a9108c2273
Ну незнаю, могут быть
А ты уверен, что нужен именно ReaderWriterLock? Операция записи значительное время занимает? По дефолту я бы врапнул в локи, или даже сделал volatile филду, да и дело с концом. Но зависит от того, какая семантика тебе нужна во время обновления токена. Если я обновляю токен вот прям щас, то другим людям ещё можно им пользоваться, или уже нет?
Самое важное забыл написать. Читателей параллельных много будет. Каждому лок выдавать жирно как-то. А писатель, рефрешер токена, один. Старый токен работает ещё минут 5, как минимум, работает. Поэтому лок на запись планировал брать именно перед самой записью, после получения нового токена. Надо защитить момент, когда в поле класса пишется новая ссылка на строку, как я понимаю. Если описывать цель, то я пишу апи клиент с авторизацией oauth2 (oidc) для использования в тестах. Параллельные тесты, параллельная генерация сущностей для теста, ещё рефит на каждый интерфейс апи создаёт новый апи клиент. Рефреш токена по таймеру планирую запускать. Потенциально мне ещё словарь юзер-токен придётся делать и что-то вокруг костылить, потому что первое получение токена ресурсоёмкое, с запуском селениума. Но до этого кода я ещё не добрался :)
Ок. Считаю, что reader-writer lock норм сработает.
https://prnt.sc/10edkm9
Мистер опять жестит.
Прикольный код. Но теряется поддержка нескольких юзеров с разными токенами из-за статика. И не получится безопасно писать/читать в поле токена. Забей, спасибо за помощь.
static тебе гарантирует безопасность
Тогда бы его назвали safe, а не static!
Ох ёпт, начинается.
А если серьёзно, то расскажи, откуда ты это взял. Это ж неверно.
Ну хз, когда-то слышал что-то такое
Когда-то у меня в многопоточном коде возникали коллапсы, потому что много потоков рвались к одному полю, ошибок не было, все потоки брали данные из static поля, и поэтому все становились в очеридь
в реббит очередь становились?
Ну так у тебя только чтение тут. Я думаю, проблема изначально была из-за того, что инициализация не статик поля происходила одновременно с попытками чтения. А вот статик гарантирует инициализацию до первого обращения.
(ну, чаще всего гарантирует, а иногда нет)
ну и. https://github.com/maksim2143/TestStaticFields/blob/master/TestStaticFields/Program.cs
Блин, не отвечай мне, пожалуйста.
Для этого был стикер, но скинуть я его не могу🌚
А я искал, и не нашёл!
могу в лс скинуть
Обсуждают сегодня