172 похожих чатов

12 ответов

19 просмотров

В теле футуры, которая спавнится? Потому что мне важно чтобы лок произошел 100% на следующей строчке после tokio::spawn, а не когда там экзекьютор запустит футуру

Артем Пятницкий
В теле футуры, которая спавнится? Потому что мне в...

Поэтому было-бы логичнее сначала ждать пока writer отпустит лок, а потом уже запускать консумеров

red75prime
Поэтому было-бы логичнее сначала ждать пока writer...

Мне считай нужно Arc<Notify> и делать notify.notify_waiters() Ты же не ждешь пока tokio:;spawn доработает? Зачем его иначе так запускать. Мне вот тоже нужно запустить в работу долгую таску (долгую это прямо минуты - часы) и каким консьюмерам нужно - те будут ждать окончания, чтобы что-то сделать (залогировать что закончилось, перезапустить или еще что-то)

Артем Пятницкий
Мне считай нужно Arc<Notify> и делать notify.notif...

Сделать обёртку над tokio::sync::broadcast::Receiver . async fn get(rx: &mut Receiver<T>) -> T { loop { match rx.recv().await { Ok(v) => return v, Err(Lagged(_)) => {} }} Ну и длину канала в 1, чтобы stale туда не попадало

red75prime
Сделать обёртку над tokio::sync::broadcast::Recei...

Но у меня нет гарантии, что после Lagged данные не поменялись. Мне нужно чтобы при recv().await данные внутри новые не пришли

Артем Пятницкий
А как размер 1 поможет от этого?

Получили Lagged, если до следующего вызова recv() пришли новые данные, то опять получим Lagged. Так что возвращаться будет только действительно последнее значение.

red75prime
Получили Lagged, если до следующего вызова recv() ...

Да, но мне нужно на момент регистрации ожидающим (как только я встал в лок recv()) чтобы данные нельзя было менять пока я не получу именно те, за которыми я встал. Проще говоря мне нужны данные именно от того эксклюзивного лока, после которого я встал в очередь

Артем Пятницкий
Да, но мне нужно на момент регистрации ожидающим (...

А то иначе это выклядит как использование mutex, что я встал в лок, но мне так и не отдали возможность их прочитать, потому что они опять встали в обработку эксклюзивную

Артем Пятницкий
Да, но мне нужно на момент регистрации ожидающим (...

То есть обычный rwlock, но нужно гарантировать, что reader'ы не заблокируют его до первого write?

red75prime
То есть обычный rwlock, но нужно гарантировать, чт...

Да. Обработка должна стартовать сразу для reader’ов, чтобы не получилось прочитать через read пустые данные, хотя таска номинально стартовала в обработку

Артем Пятницкий
Да. Обработка должна стартовать сразу для reader’о...

Сейчас это кастомный тип с двумя Notify и AtomicUsize которые просто будят в нужный момент либо эксклюзивный лок, либо все шаренные локи

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Ребят в СИ можно реализовать ООП?
Николай
33
у вас два процесса. один посылает другому сигнал. у вас есть код обоих процессов? если всё не так - расскажите как оно на самом деле. а именно кто кому чего, есть-ли консоли,...
Karagy
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Карта сайта