Portál AbcLinuxu, 20. dubna 2024 08:13


Dotaz: Actor model - a reply channel

31.5.2019 20:20 Brad Pitt
Actor model - a reply channel
Přečteno: 210×
Odpovědět | Admin

Ahojte robím si jeden parser a bohužiaľ používam knižnicu, ktorá je tak neštastne navrhnutá, že musím na jednom mieste použiť imperatívny kód (počítadlo pre riadky a stĺpce). A keďže obyčajné inkrementovanie hodnoty v multitheardovom prostredí neni bezpečné rozhodol som sa namiesto lockovania použiť actor model.

Používam na to triedu MailboxProcessor a tá má 3 metódy na komunikovanie s okolitým svetom (má ich viac ale tie teraz nie sú podstatné)

No a teraz stojím pred dilemou čo mám kde použiť? Intuícia mi hovorí že by som mal asi všade použiť PostAndAsyncReply keď chcem aby bolo všetko tip top pretože nechcem nič zbytočne blokovať zároveň ale chcem vedieť či už nastala akcia (inkrementovanie hodnoty). A až po jej inkrementovaní môžem poslať metódou PostAndAsyncReply správu Fetch ktorá mi vráti inkrementovanú hodnotu. Ja dávam asyncReplyChanel úplne všade aj za setovanie hodnoty lebo chcem vedieť kedy akcia prebehla.

Lenže proti tomuto riešeniu zase hovorí réžia spojená s asynchrónnymi operáciami a kladiem si otázku či takéto riešenie neni kanón na vrabce ktorý spomaluje zozložiťuje kód veď inkremenovanie čísla je veľmi nenáročná operácia ktorá zaberie zanedbatelne málo času Lenže keď budem mať v aplikácii viac agentov ktoré budú navzájom komunikovať tak potrebujem mať 100% istotu v poradí niektorých operácií.

Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

31.5.2019 23:58 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
Rozbalit Rozbalit vše Re: Actor model - a reply channel
Odpovědět | | Sbalit | Link | Blokovat | Admin
Lenže keď budem mať v aplikácii viac agentov ktoré budú navzájom komunikovať tak potrebujem mať 100% istotu v poradí niektorých operácií.
Stačí, aby se dané závislé operace spustily až tehdy, když budou splněny všechny předpoklady, na kterých ty operace závisí.
-- OldFrog
1.6.2019 10:07 Razor
Rozbalit Rozbalit vše Re: Actor model - a reply channel
Odpovědět | | Sbalit | Link | Blokovat | Admin
Pokud chceš actor model, použil bych hotové řešení např. Akka. Pokud jde pouze o bezpečnou inkrementaci integru AtomicInteger (pro java) či ekvivalent pro tvůj jazyk nestačí?
1.6.2019 22:36 Brad Pitt
Rozbalit Rozbalit vše Re: Actor model - a reply channel
Ahoj dakujem za tip. V čom je lepšia tá Akka oproti MilboxProcessor-u? Pozeral som si príklady a príde mi to +- to isté.

Idem si tú Akku pridať do projektu a trošku s ňou poexperimentujem.

"Pokud jde pouze o bezpečnou inkrementaci integru AtomicInteger (pro java) či ekvivalent pro tvůj jazyk nestačí?"

Na tento 1 konkrétny účel by možno aj stačilo.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.