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

Как крутые ФП-перцы работают с мутабельностью? У меня есть здоровенный двумерный

массив примитивов, и есть поток событий (более-менее последовательных, но могут быть редкие гонки), которые обновляют часть этого массива (не в пределах одной строки или столбца, а скорее куб).
Использовать неизменяемые структуры - не вариант (даже не столько из-за производительности, сколько из-за памяти - двумерный массив занимает большую часть хипа).
Пытался на zio использовать Semaphore + Ref, но результат получался очень уж "колхозным".
В итоге сделал на akka акторе (благо там по контракту happens before между обработками сообщений).
Есть вообще инструменты для такого в zio или котах?

16 ответов

7 просмотров

fs2.Stream + Ref

а как связано кручение матрицы и акторы?

Simon- Автор вопроса
RSN
fs2.Stream + Ref

и как? update нельзя - не гарантируется однократность Ref вообще не предназначен для мутабельных структур

Simon- Автор вопроса
Simon
happens before между действиями.

а акторы не дают total order?

Simon- Автор вопроса
Nikolay
а акторы не дают total order?

дают. именно потому я и взял актор

Simon- Автор вопроса
RSN
fs2.Stream + Ref

есть пример как там обеспечить happens before на метабельной структуре данных? то, что я сделал было слишьком колхозно - актор и то лучше выглядел.

Simon
есть пример как там обеспечить happens before на м...

Не надо в Ref использовать мутабельную, используй иммьютабл

Simon- Автор вопроса
RSN
Не надо в Ref использовать мутабельную, используй ...

Мышки, станьте ёжиками... Я сразу написал, что на неизменяемую структуру переделать не получится - в память не влезет.

Simon- Автор вопроса
Simon
есть пример как там обеспечить happens before на м...

Еще бы понять hp между чем и чем вам нужно

Simon
и как? update нельзя - не гарантируется однократно...

А уверены что в акторах гарантируется exactly once и все остальное что вам надо?

Simon- Автор вопроса
Artem Sokolov
А уверены что в акторах гарантируется exactly once...

Актор у меня локальный + ask. Так что там at most once + если оно когда-нибудь таки не дойдет - я узнаю.

Simon- Автор вопроса
Artem Sokolov
Еще бы понять hp между чем и чем вам нужно

Между записями в массив. Чтоб одна запись не перетерла соседние элементы от другой.

Simon
Мышки, станьте ёжиками... Я сразу написал, что на ...

Может лучше взять другую структуру данных нежели матрицу?

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

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

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
> комьюнити я бы не судил по этому чату. Как мы видели по статам просмотров нескольких телеговских постов, то в чате их набивается 30-40 или даже выше, когда как общаются акти...
Constantin F.
4
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Как сделать чтобы short точно был 2 байта, int точно 4 байта ?(без стандартных библиотек, ну типа без int16_t, int32_t)
#
8
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Только такой if ($modx->event->name == 'OnBeforeCartItemAdding') { $meta = $params['item']['meta']; $lang = $modx->getConfig('_lang'); // проверяем, задана ли опция i...
Multi Web
1
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
Карта сайта