abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 14:00 | Komunita

    Svobodný operační systém ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, slaví 30. narozeniny.

    Ladislav Hagara | Komentářů: 1
    dnes 11:00 | IT novinky

    Společnost Raspberry Pi má nově v nabídce flash disky Raspberry Pi Flash Drive: 128 GB za 30 dolarů a 256 GB za 55 dolarů.

    Ladislav Hagara | Komentářů: 2
    dnes 10:22 | Zajímavý software

    Technologie Skip pro multiplatformní mobilní vývoj, která umožňuje vývojářům vytvářet iOS a Android aplikace z jediné Swift a SwiftUI kódové základny, se s vydáním verze 1.7 stala open source.

    Ladislav Hagara | Komentářů: 0
    dnes 03:33 | Zajímavý software Ladislav Hagara | Komentářů: 1
    dnes 00:11 | Nová verze

    Byla vydána nová major verze 34.0.0 webového prohlížeče Pale Moon (Wikipedie) vycházejícího z Firefoxu. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 16:11 | Humor

    Win8DE je desktopové prostředí pro Wayland, inspirované nechvalně proslulým uživatelským rozhraním Metro z Windows 8. Nabízí dlaždicové rozhraní s velkými tlačítky a jednoduchou navigací, optimalizované pro dotyková zařízení. Cílem projektu je přetvořit design operačního systému Windows 8 do funkčního a minimalistického rozhraní vhodného pro každodenní použití na Linuxu.

    NUKE GAZA! 🎆 | Komentářů: 11
    včera 14:33 | Nová verze

    Laboratoře CZ.NIC vydaly Datovku 4.28.0 a Mobilní Datovku 2.6.0. Hlavní novinkou je ukládání rozpracovaných datových zpráv do konceptů. Datovka je svobodné multiplatformní aplikace pro přístup k datovým schránkám a k trvalému uchovávání datových zpráv v lokální databázi.

    Ladislav Hagara | Komentářů: 6
    včera 14:22 | Zajímavý projekt

    Unix Pipe Game je vzdělávací karetní hra zaměřená na děti a rodiče, která děti učí používat unixové příkazy prostřednictvím interaktivních úkolů. Klíčovým prvkem hry je využití symbolu | pro pipeline neboli 'rouru', který umožňuje propojit výstupy a vstupy jednotlivých unixových příkazů, v tomto případě vytištěných na kartičkách. Předpokládá se, že rodič má alespoň nějaké povědomí o unixových příkazech a jejich provazování pomocí |.

    … více »
    NUKE GAZA! 🎆 | Komentářů: 3
    včera 13:55 | Zajímavý software

    PCIem je linuxový framework, který vytváří virtuální zařízení PCIe pomocí technik, které umožňují hostitelskému operačnímu systému rozpoznat tyto syntetické 'neexistující' karty jako fyzické zařízení přítomné na sběrnici. Framework PCIem je primárně zamýšlen jako pomůcka pro vývoj a testování ovladačů bez nutnosti použít skutečný hardware. Dle tvrzení projektu si fungování PCIem můžeme představit jako MITM (Man-in-the-Middle), který se nachází mezi ovladači a kernelem.

    NUKE GAZA! 🎆 | Komentářů: 1
    včera 05:33 | Bezpečnostní upozornění

    Byla nalezena vážná bezpečnostní chyba v telnetd z balíčku GNU InetUtils. Týká se verzí GNU InetUtils od 1.9.3 z 12. května 2015 až po aktuální 2.7 z 14. prosince 2025. Útočník může obejít autentizaci a získat root přístup, jelikož telnetd nekontroluje předaný obsah proměnné prostředí USER a pokud obsahuje "-f root"…

    Ladislav Hagara | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (5%)
     (0%)
     (10%)
     (21%)
     (3%)
     (5%)
     (2%)
     (11%)
     (36%)
    Celkem 568 hlasů
     Komentářů: 17, poslední dnes 15:24
    Rozcestník

    Dotaz: Actor model - a reply channel

    31.5.2019 20:20 Brad Pitt
    Actor model - a reply channel
    Přečteno: 256×

    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é)

    • Post – pošlem asynchrónnu správu a ďalej nič neriešim
    • PostAndReply – pošlem asynchrónnu správu a čakám na synchrónnu odpoveď – možem si tam nastaviť timeout
    • PostAndAsyncReply – pošlem asynchrónnu správu a čakám na asynchrónnu odpoveď

    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í.

    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
    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
    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   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.