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 05:33 | Nová verze

    Bun (Wikipedie), tj. běhové prostředí (runtime) a toolkit pro JavaScript a TypeScript, alternativa k Node.js a Deno, byl vydán ve verzi 1.3. Představení novinek také na YouTube. Bun je naprogramován v programovacím jazyce Zig.

    Ladislav Hagara | Komentářů: 2
    včera 14:22 | IT novinky

    V Lucemburku byly oznámeny výsledky posledního kola výzev na evropské továrny pro umělou inteligenci neboli AI Factories. Mezi úspěšné žadatele patří i Česká republika, potažmo konsorcium šesti partnerů vedené VŠB – Technickou univerzitou Ostrava. V rámci Czech AI Factory (CZAI), jak se česká AI továrna jmenuje, bude pořízen velmi výkonný superpočítač pro AI výpočty a vznikne balíček služeb poskytovaný odborníky konsorcia. Obojí bude sloužit malým a středním podnikům, průmyslu i institucím veřejného a výzkumného sektoru.

    Ladislav Hagara | Komentářů: 11
    včera 01:22 | Nová verze

    Byla vydána (𝕏) zářijová aktualizace aneb nová verze 1.105 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.105 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    9.10. 15:33 | Komunita

    Ve Firefoxu bude lepší správa profilů (oddělené nastavení domovské stránky, nastavení lišt, instalace rozšíření, uložení hesla, přidání záložky atd.). Nový grafický správce profilů bude postupně zaváděn od 14.října.

    Ladislav Hagara | Komentářů: 0
    9.10. 12:44 | Nová verze

    Canonical vydal (email) Ubuntu 25.10 Questing Quokka. Přehled novinek v poznámkách k vydání. Jedná se o průběžné vydání s podporou 9 měsíců, tj. do července 2026.

    Ladislav Hagara | Komentářů: 0
    9.10. 12:22 | Nová verze

    ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzi 1.5.0.

    Ladislav Hagara | Komentářů: 0
    9.10. 01:22 | Nová verze

    Byla vydána nová verze 1.12.0 dynamického programovacího jazyka Julia (Wikipedie) určeného zejména pro vědecké výpočty. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Aktualizována byla také dokumentace.

    Ladislav Hagara | Komentářů: 0
    8.10. 15:11 | Bezpečnostní upozornění

    V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).

    Ladislav Hagara | Komentářů: 5
    8.10. 14:00 | IT novinky

    Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.

    Ladislav Hagara | Komentářů: 20
    8.10. 12:33 | Zajímavý software

    Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (46%)
     (16%)
     (17%)
     (21%)
     (16%)
     (17%)
     (16%)
     (16%)
    Celkem 206 hlasů
     Komentářů: 13, poslední 8.10. 07:41
    Rozcestník

    Dotaz: Sdílená pamět --> pole

    15.4.2011 10:13 Honza
    Sdílená pamět --> pole
    Přečteno: 555×

    Ahoj jsem v C/C++ trochu začátečník a chtěl bych se zeptat jak udělat abych do sdílený paměti u procesů dostal celý pole??Dostanu tam třeba celou strukturu ale jak tam dostat pole mi moc jasny neni jestli to teda vůbec jde.

    tohle je muj kod:

    #include <stdio.h>
    #include <sys/shm.h>
    #include <sys/stat.h>

    int main(){
    int segment_id;
    //int *shared_memory;
    struct shmid_ds shmbuffer;
    int segment_size;
    const int shared_segment_size = 0x6400;

    typedef struct struct_kamion{
    int id;
    int kolik;
    };
    struct_kamion pole_kamionu[2];

    struct_kamion *shared_memory;

    struct_kamion kamion = {1111,1};
    pole_kamionu[0] = kamion;
    struct_kamion kamion2 = {2222,2};
    pole_kamionu[1] = kamion2;
    /* Alokovani sdileneho pametoveno segmentu */
    segment_id = shmget(IPC_PRIVATE, shared_segment_size, IPC_CREAT | IPC_EXCL | S_IRUSR | S_IWUSR);

    /* Pripojeni sdileneho segmentu */
    shared_memory = (struct_kamion *) shmat(segment_id, NULL, NULL);
    printf("sdilena pamet byla pripojena na adresu %p\n", shared_memory);
    /* Urceni velikosti segmentu */
    shmctl(segment_id, IPC_STAT, &shmbuffer);
    segment_size = shmbuffer.shm_segsz;
    printf("velikost segmentu: %d\n", segment_size);
    /* Zapsani retezce do sdileneho pametoveho segmentu */
    shared_memory[0] = pole_kamionu[0];
    //shared_memory->id = pole_kamionu[0].id;  

    //sprintf(shared_memory, 23);
    /* Odpojeni pametoveho segmentu */
    shmdt(shared_memory);

    /* Nove pripojeni sdileneho segmentu( na urcitou adresu) */
    shared_memory = (struct_kamion*) shmat(segment_id, (void *) 0x5000000, NULL);
    printf("sdilena pamet byla pripojena na adresu %p\n", shared_memory);
    /* Vypis retezce ze sdilene pameti */
    int idKamionu = 4;//shared_memory->id;
    printf("%d\n", idKamionu);
    /* Odpojeni segmentu */
    shmdt(shared_memory);

    /* Dealokovani sdileneho pametoveho segmentu */
    shmctl(segment_id, IPC_RMID, NULL);

    return(0);
    }

    Odpovědi

    15.4.2011 16:18 Sten Fil
    Rozbalit Rozbalit vše Re: Sdílená pamět --> pole
    Se sdilenou je to podobne jako s malloc. Nejlepe na zacatku prg. alokace a na konci to vse uvolnis.

    Zaalokujes si napr. pro 10 zaznamu kamion. sizeof (kamion) * 10.

    A pak pomoci ukazatele pristupujes na jednotlive zaznamy.

    17.4.2011 13:09 Honza
    Rozbalit Rozbalit vše Re: Sdílená pamět --> pole
    A jak bych tam třeba dostal ještě dvourozměrný pole??
    17.4.2011 14:46 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: Sdílená pamět --> pole
    nasimulujes je pomoci jednorozmernyho pole.

    To znamena alokujes

    sizeof(kamion) * pocet_radku * pocet_sloupcu

    a potom misto

    pole[radek][sloupec]

    k tomu pristupujes pomoci

    pole[radek * pocet_sloupcu + sloupec]
    17.4.2011 15:08 zvj
    Rozbalit Rozbalit vše Re: Sdílená pamět --> pole
    Princip je porad stejnej. Shmat() ti pripoji pozadovanej segment a pokud vsechno dobre dopadne tak vrati void pointer na prvni byte. Tenhle pointer si pretypujes na co potrebujes. Pokud chces treba 2-rozmerny pole intu pretypujes na int**.
    int** pole = (int**) shmat(segment_id, NULL, NULL); 
    
    pole[0][0] = ...

    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.