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í
×
    včera 07:33 | Komunita

    O víkendu probíhá konference OpenAlt 2025. Na programu je spousta zajímavých přednášek. Pokud jste v Brně, stavte se. Vstup zdarma.

    Ladislav Hagara | Komentářů: 0
    včera 00:55 | IT novinky

    Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.

    Ladislav Hagara | Komentářů: 7
    31.10. 18:33 | IT novinky

    Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).

    Ladislav Hagara | Komentářů: 0
    31.10. 13:22 | Komunita

    Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).

    Ladislav Hagara | Komentářů: 8
    31.10. 01:22 | Nová verze

    Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    31.10. 00:11 | IT novinky

    Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.

    Ladislav Hagara | Komentářů: 5
    30.10. 23:44 | Komunita

    Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.

    Ladislav Hagara | Komentářů: 0
    30.10. 15:22 | Nová verze

    Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 2
    30.10. 12:55 | Nová verze

    Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).

    Ladislav Hagara | Komentářů: 1
    30.10. 02:55 | Nová verze

    Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (19%)
     (18%)
     (22%)
     (16%)
     (20%)
     (16%)
     (17%)
    Celkem 295 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Dotaz: C; pointer na fciu v strukture

    20.12.2010 16:50 mato
    C; pointer na fciu v strukture
    Přečteno: 523×
    Cafte, pri rieseni problemu sm narazil na zaujimavy problem, pri ktorom som si nie celkom isty. Otazka znie: je spravne menit adresu fcie pocas jej behu (po zavolani)? Otazka asi nie je polozena uplne spravne .. na ukazku kod:
    #include <stdio.h>
    
    /* fwd deklaracia */
    struct point __point;
    
    /* exec fcia */
    typedef int(*f_execute)(struct point* p);
    
    struct point {
            int x;
            int y;
            int z;
    
            f_execute       exec;
    };
    
    int exec_primary(struct point* p);
    int exec_secondary(struct point* p);
    
    int main()
    {
            struct point p;
    
            p.x = p.y = p.z = 0;
            p.exec = &exec_primary;
    
            /* execute */
            while (p.exec != NULL) {
                    p.exec(&p);
    
                    printf ("DEBUG: p: [%d,%d,%d]\n", p.x, p.y, p.z);
            }
    
            return 0;
    }
    
    int exec_primary(struct point* p)
    {
            p->x += 4;
            p->y += 2;
            p->z += 1;
    
            p->exec = &exec_secondary;
            return 0;
    }
    
    int exec_secondary(struct point* p)
    {
            p->x *= 2;
            p->y *= 4;
            p->z *= 3;
    
            p->exec = NULL;
            return 0;
    }
    
    
    Nech mam struktutu point, ktora v sebe ma okrem suradnic aj pointer na fciu, ktoru ma vykonat. Na zaciatku je exec nastaveny na prvu, zakladnu exec fciu exec_primary. Ta pocas svojho behu zmeni point exec pointer na druhu fciu, exec_secondary
    mozem mat zadefinovany neobmedzeny pocet exec fcii, ktory nie je vopred znamy, pripadne sa dynamicky meni od systemu

    vsetko funguje ako ma, no nie som si isty ci je toto spravne, resp. uplne koser riesenie.

    musim si pozriet hlbsie teoriu o tom, ako su fcie volane (tj. mngmnt ohladne volani fcii), ale mozno mi niektori z vas budete vediet poradit, resp. nasmerovat, ci je takyto sposob v poriadku

    vopred vdaka

    Odpovědi

    20.12.2010 17:59 R
    Rozbalit Rozbalit vše Re: C; pointer na fciu v strukture
    Nemenis "adresu funkcie", ale menis nejaky pointer ulozeny v strukture. Ze je v nom ulozena adresa samotnej funkcie, to je nezaujimave. Volanie funkcie uz bolo vykonane a do dalsieho volania ten pointer nebude potrebny.

    Pre pochopenie si predstav kod v assembleri - funkciu zavolas (CALL), potom bezi a nakoniec sa vrati (RET).
    20.12.2010 18:52 mato
    Rozbalit Rozbalit vše Re: C; pointer na fciu v strukture
    ano, pravda..zle som sa vyjadril v tej otazke ..

    dobre si to naznacil s tym CALL/RET .. RET bude adresa <main>; to ze je v strukture pointer na adresu, ktoru som zavolal a zaroven strukturu pozmenil je jedno (tj. je jedno ci menil integer alebo pointer (co je koniec koncov zas len cislo)

    .. uz sa dlhsi cas chystam pozriet si info ohladne volanie fcia a mngmnt stack-u .. zimne vecery su ten idealny cas

    diq

    21.12.2010 12:10 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: C; pointer na fciu v strukture
    No nevím jakou logiku se tím snažíte naprogramovat, ale nebylo by jednodušší prostě ty funkce zavolat rovnou za sebou?
    In Ada the typical infinite loop would normally be terminated by detonation.
    21.12.2010 12:46 mato
    Rozbalit Rozbalit vše Re: C; pointer na fciu v strukture
    ten horeuvedeny priklad sluzi len ako ukazka principu, co pouzivam vo svojom kode ja ..

    problem spociva v tom, ze pocet funkcii nie je vopred znamy a je definovany uzivatelom .. moze ich byt lubovolne vela, kde posledna fcia musi byt NULL.
    jedna sa (resp. bude sa jednat) o kniznicu simulacneho jadra, kde entita zijuca v systeme prechadza lubovolnym poctom eventov; zo systemu odchadza, ked je jej exec nastaveny na NULL

    pavlix avatar 21.12.2010 19:30 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: C; pointer na fciu v strukture
    Pak nevidím problém během volání funkce ukazatel nastavit na novou funkci. S CALL a RET to nemá nic společného. Jediná souvislost mezi strukturou a funkcí je v tomhle případě, že se struktura na funkci odkazuje.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    21.12.2010 19:51 __dark__
    Rozbalit Rozbalit vše Re: C; pointer na fciu v strukture
    Tvuj pristup je v poradku. Adresa funkce se nacte pokazde, kdyz se ma funkce zavolat. Jak uz bylo zmineno, ty nemenis adresu te funkce, ale jen ukazatel. Akorat si ted nejsem jisty tim struct point __point;, nemelo by tam byt jen struct point;?
    22.12.2010 10:10 mato
    Rozbalit Rozbalit vše Re: C; pointer na fciu v strukture
    s tou fwd declaraciou mas pravdu, uplne by postacilo
    
    struct point;
    
    __point je uz zadef. premenna, co trosku mozno nema zmysel .. ja to (zne)uzivam na to, aby som videl, ze je to to fwd declaracia - bije mi to do oci hned ked otvorim zdrojak ..

    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.