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

Вот смотрю язык, нраица. Только вот не понял, а как сделать

такую штуку

Есть канал. У канала 1 воркер, несколько отправителей

Есть воркер-горутина. Он слушает канал. Дабы не потреблять в for-select-case-default много ресурсов cpu, и не костылить со Sleep в дефолте, пока из канали не придёт сообщение, воркер ждёт. Читай — заблокирован в for-select-case

Есть много горутин-отправителей, у них есть ссылка на канал, горутины-отправители могут просыпаться в любой момент.

Вопрос прост — почему я не могу сделать так, чтобы у меня крутился forever воркер и хендлил сообщения в канале от sender’ов? Сплошные дедлоки…

15 ответов

24 просмотра

А код можно? Или репродьюс. Желательно на play.golang.org

𝖁𝖎𝖙𝖆𝖑𝖎𝖞-𝕾 Автор вопроса

В эрланге проще. Там воркеры-gen_server по умолчанию заблокированы без сообщений и слушают “почтовый ящик”

𝖁𝖎𝖙𝖆𝖑𝖎𝖞 𝕾
В эрланге проще. Там воркеры-gen_server по умолчан...

Вообще если вы в форе слушаете канал, в селекте без дефолта или в явной форме (a := <- ch), то он будет заблокирован пока не появится данных

𝖁𝖎𝖙𝖆𝖑𝖎𝖞-𝕾 Автор вопроса
Евгений Омельченко
Вообще если вы в форе слушаете канал, в селекте бе...

Ща, тогда просто попробую запустить слушалку (playground скину)

А кто мешает просто заблокироваться на чтении из канала? Типа for { select { case task := <- tasks: // do tasks case <-ctx.Done() } }

𝖁𝖎𝖙𝖆𝖑𝖎𝖞 𝕾
🤔 изучу

https://tour.golang.org/welcome/1 https://gobyexample.com/

𝖁𝖎𝖙𝖆𝖑𝖎𝖞-𝕾 Автор вопроса
Евгений Омельченко
Вообще если вы в форе слушаете канал, в селекте бе...

Дико извиняюсь. Не могу воспроизвести. Вчера мог воспроизвести, сейчас код с нуля написал (не сохранилось, как оказалось), и проблемы не возникло. worker висит, ждёт, отрабатывает сообщения жобы отправляют в канал сообщения WaitGroup нормально отрабатывает. 😅

Ещё советую for range, если канал один

𝖁𝖎𝖙𝖆𝖑𝖎𝖞-𝕾 Автор вопроса
Евгений Омельченко
Ещё советую for range, если канал один

Баг попався! https://play.golang.org/p/RoN1qVP86j9 Как я понял, проблема том, что for range {} ждёт сообшения из незакрытого канала, в который никто никогда не напишет. Но как закрыть канал, если отправителей много?

𝖁𝖎𝖙𝖆𝖑𝖎𝖞-𝕾 Автор вопроса

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта