abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:11 | Nová verze

    Rocky Linux byl vydán v nové stabilní verzi 9.4. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 22:22 | Bezpečnostní upozornění

    Dellu byla odcizena databáze zákazníků (jméno, adresa, seznam zakoupených produktů) [Customer Care, Bleeping Computer].

    Ladislav Hagara | Komentářů: 5
    včera 21:11 | Zajímavý článek

    V lednu byl otevřen editor kódů Zed od autorů editoru Atom a Tree-sitter. Tenkrát běžel pouze na macOS. Byl napevno svázán s Metalem. Situace se ale postupně mění. V aktuálním příspěvku Kdy Zed na Linuxu? na blogu Zedu vývojáři popisují aktuální stav. Blíží se alfa verze.

    Ladislav Hagara | Komentářů: 14
    včera 14:33 | Pozvánky

    O víkendu 11. a 12. května lze navštívit Maker Faire Prague, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    8.5. 21:55 | Nová verze

    Byl vydán Fedora Asahi Remix 40, tj. linuxová distribuce pro Apple Silicon vycházející z Fedora Linuxu 40.

    Ladislav Hagara | Komentářů: 31
    8.5. 20:22 | IT novinky

    Představena byla služba Raspberry Pi Connect usnadňující vzdálený grafický přístup k vašim Raspberry Pi z webového prohlížeče. Odkudkoli. Zdarma. Zatím v beta verzi. Detaily v dokumentaci.

    Ladislav Hagara | Komentářů: 6
    8.5. 12:55 | Nová verze

    Byla vydána verze R14.1.2 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.

    JZD | Komentářů: 1
    7.5. 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 10
    7.5. 18:33 | IT novinky

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 4
    7.5. 17:11 | Nová verze

    Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (63%)
     (8%)
     (13%)
     (16%)
    Celkem 148 hlasů
     Komentářů: 10, poslední 8.5. 17:35
    Rozcestník

    Dotaz: Spristupnenie pamatovych struktur potomkovi

    16.10.2008 12:37 xsustek | skóre: 6
    Spristupnenie pamatovych struktur potomkovi
    Přečteno: 212×
    Zdravim,

    mam takyto problem. Su dva procesy: rodic a potomok. Rodic sa periodicky budi a ziskava informacie. Potomok caka na UDP a pri dotaze musi nahliadnut do rodicovskych pamatovych strukur resp. musi od neho ziskat nejake info resp. citat jeho pamat.

    Robim to v C-ku a v Linuxe. Nechcem k tomu pouzit vlakna. Zaujima ma ake su moznosti. Nedalo by sa to nejakou rurou? Alebo niecim inym?

    Dakujem

    Odpovědi

    16.10.2008 13:51 Jirka P
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Ta otázka je dost obsáhlá... Dala by se použít roura, unix-domain socket, sdílená paměť, společný soubor... cokoli.
    16.10.2008 14:00 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Co si myslite, ze by bolo najednoduchsie.

    Rodic bude mat staticky alokovanu pamat. Napr. 5 struktur.

    Chcel by som sa ale vyhnut nejakemu binarnemu citaniu. (nieco v tom zmysle, ze by citajuci cital prud dat a nejak ich musel zozpoznavat. Tak isto by som sa chcel vyhnut tomu, aby sa rodic musel prebudit a poskytnut data.

    Viem, ze je to dost nejasne sam v tom nemam uplne jasno. :(

    16.10.2008 14:54 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    v tomto prípade by som osobne použil zdieľanú pamäť
    16.10.2008 15:59 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Mohli by ste ma nejako nasmerovat. Su nejane systemove volanie v Linuxe pre to. Ako sa to oficialne vola, aby som si to mohol vyhladat na internete.
    16.10.2008 16:12 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Buď můžete použít mmap, který by měl přes fork krásně fungovat (man mmap), nebo řekl bych klasičtější System V IPC (viz man shmat).
    16.10.2008 16:07 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Buď sdílená paměť, nebo rodič po získání informací tyto "natlačí" do potomka, který si je zapamatuje, aby je mohl posílat přes UDP. (Což je v podstatě stejný přístup jako sdílená paměť.) To mi připadají jako jediné možnosti, pokud se chceš vyhnout probouzení rodiče pro poskytnutí dat. Pak by se dal použít ještě trochu úchylnější přístup, a to po získání dat rodičem potomka zabít a znovu forknout s novými daty.

    Jen bych upozornil, že přestože se nejedná o vlákna, při přístupu do sdílené paměti by se AFAIK měla použít nějaká synchronizace, např. mutexy (ty by ve sdílené paměti měly fungovat i mezi procesy).

    Nějak jsem nepochopil, že se chceš vyhnout binárnímu čtení. Číst musíš vždycky :-)
    16.10.2008 16:24 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Nějak jsem nepochopil, že se chceš vyhnout binárnímu čtení.
    Myslel som to tak, ze tie struktury v pamati budem moct citat podobne ako by ich cital proces ktoremu patria. Napr. takto st_rec.name. A nemusel to citat ako nejaky prud dat, kde by som musel vediet kde jedna premenna konci a ina zaciana.

    Takze hovorite, ze zdielana pamat. Tak skusime.
    16.10.2008 16:26 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    nebo rodič po získání informací tyto "natlačí" do potomka, který si je zapamatuje
    mohli by ste toto konktretne specifikovat, ako by sa to dalo urobit? Musela by tam byt nejaka aktivita na strane potomka. resp. musel by data nejak spracovavat?
    16.10.2008 16:46 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Myslel jsem třeba rourou nebo prostě něčím, na co se v rodičovi zavolá write() a v potomkovi read() (nebo samozřejmě fwrite a fread). Přijatá data by se samozřejmě musela zpracovat, ale pokud se to udělá pěkně, nejsou s tím žádné potíže, protože ty data nemusí být multiplatformní (běží to na jednom stroji, že); fread(ptr, sizeof(*ptr), 1, stream); ptr->name není už tak hrozné. Akorát by se v potomkovi muselo zacházet s dvěma vstupy naráz (UDP a tahle roura), a to je trochu složitější - buď přes přes select() nebo neblokující režim. Sdílená paměť bude opravdu lepší řešení, pokud je možné ji použít.
    16.10.2008 17:38 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Příloha:
    Ještě zpět k těm mutexům - mutex se musí nastavit jako process-shared pomocí (pthread_mutexattr_setpshared(&attr, PTHREAD_PROCESS_SHARED). Do přílohy jsem kdyžtat sesmolil ukázkový program, který dělá zhruba to co xsustek chce (abych si vyzkoušel, že to co radím doopravdy funguje). Dost by mě zajímalo srovnání výkonu oproti jiné meziprocesové synchronizaci...
    16.10.2008 20:32 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Za toto musim fakt podakovat. Este som to neskusal, uz je vecer :). Skusim to cez vikend pripadne odpisem. DIK
    16.10.2008 16:58 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Nechcem k tomu pouzit vlakna.

    To je docela chyba, protože právě tohle je jedna z největších výhod threadů. Můžete sice použít sdílenou paměť, ale tím si nepomůžete, stejně budete muset řešit otázku synchronizace (např. pomocí semaforů).

    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.