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 15:00 | Nová verze

    Všem vše nejlepší do nového roku 2026.

    Ladislav Hagara | Komentářů: 0
    dnes 13:33 | Zajímavý software

    Crown je multiplatformní open source herní engine. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT a GPLv3+. Byla vydána nová verze 0.60. Vyzkoušet lze online demo.

    Ladislav Hagara | Komentářů: 0
    dnes 12:11 | Zajímavý článek

    Daniel Stenberg na svém blogu informuje, že po strncpy() byla ze zdrojových kódů curlu odstraněna také všechna volání funkce strcpy(). Funkci strcpy() nahradili vlastní funkcí curlx_strcopy().

    Ladislav Hagara | Komentářů: 1
    dnes 03:00 | Nová verze

    Byla vydána nová verze 25.12.30 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

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

    Společnost Valve publikovala přehled To nej roku 2025 ve službě Steam aneb ohlédnutí za nejprodávanějšími, nejhranějšími a dalšími nej hrami roku 2025.

    Ladislav Hagara | Komentářů: 0
    včera 16:11 | Komunita

    Byly publikovány výsledky průzkumu mezi uživateli Blenderu uskutečněného v říjnu a listopadu 2025. Zúčastnilo se více než 5000 uživatelů.

    Ladislav Hagara | Komentářů: 0
    včera 03:33 | Bezpečnostní upozornění

    V dokumentově orientované databázi MongoDB byla nalezena a v upstreamu již opravena kritická bezpečností chyba CVE-2025-14847 aneb MongoBleed.

    Ladislav Hagara | Komentářů: 0
    29.12. 23:11 | IT novinky

    Při úklidu na Utažské univerzitě se ve skladovacích prostorách náhodou podařilo nalézt magnetickou pásku s kopií Unixu V4. Páska byla zaslána do počítačového muzea, kde se z pásky úspěšně podařilo extrahovat data a Unix spustit. Je to patrně jediný známý dochovaný exemplář tohoto 52 let starého Unixu, prvního vůbec programovaného v jazyce C.

    🇨🇽 | Komentářů: 4
    29.12. 15:55 | Komunita

    FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.

    🇨🇽 | Komentářů: 7
    29.12. 15:44 | Zajímavý software

    K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.

    🇨🇽 | Komentářů: 1
    Kdo vám letos nadělí dárek?
     (31%)
     (1%)
     (26%)
     (1%)
     (1%)
     (1%)
     (10%)
     (10%)
     (18%)
    Celkem 210 hlasů
     Komentářů: 22, poslední dnes 15:34
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: zrychlení opakovaného volání virtuálních funkcí pomocí boost::bind?

    14.11.2009 22:34 vencas | skóre: 32
    zrychlení opakovaného volání virtuálních funkcí pomocí boost::bind?
    Přečteno: 199×
    Zdravím,

    chci se zeptat (než to budu pořádně zkoušet a měřit), jestli je možné urychlit časté a opakované volání virtuální funkce na objektu tak, že udělám virtuální funkci vracející pointer na nevirtuální funkci, která se příště bude (přes ten pointer) volat přímo, nevirtuálně. Využiju k tomu navázání pointeru na instanci pomocí boost::bind.

    Původní scénář:
    struct A{
       virtual int compute(int foo){ /* výpočet A */ }
    };
    struct B: public A{
       virtual int compute(int foo){ /* výpočet B */ }
    };
    
    vector<objekt*> objekty; // naplnit pole etc.
    
    for(int i=0; i<100000; i++){
       // tady se pro každý objekt v každém kroku resolvuje virtuální funkce, přitom výsledek pro kažedý objekt vždy stejný
       BOOST_FOREACH(const objekt*, objekty){ sum+=objekt->compute(bar); }
    }
       
    
    kde je nějaká množina objektů, na kterých se compute mnohokrát opakovaně volá.

    Nový scénář:
    struct A{
       typedef boost::function<int(int)> computePtrT;
       computePtrT compuptePtr;
       int computeA(int foo){ /* výpočet A */ } // neni virtualni!
       virtual computePtrT getComputePtr(){ return boost::bind(&A::computeA,this,_1); }
    };
    struct B: public A{
       int computeB(int foo){ /* výpočet B */ } // neni virtualni
       virtual computePtrT getComputePtr(){ return boost::bind(&B::computeB,this,_1); }
    };
    
    for(int i=0; i<100000; i++){
       BOOST_FOREACH(const objekt*, objekty){
          // při prvním cyklu se voláním virtuální funkce nastaví pointer na nevirtuální funkci (computeA nebo computeB)
          if(!objekt->computePtr) objekt->computePtr=objekt->getComputePtr();
          sum+=objekt->computePtr(bar);
       }
    }
    
    Díky za komentáře.

    Řešení dotazu:


    Odpovědi

    14.11.2009 23:06 Jirka P.
    Rozbalit Rozbalit vše Re: zrychlení opakovaného volání virtuálních funkcí pomocí boost::bind?
    Silně pochybuji - dokonce myslím, že zrychlení není možné, protože samotný boost::function při volání používá virtuální funkci.
    15.11.2009 16:36 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: zrychlení opakovaného volání virtuálních funkcí pomocí boost::bind?
    Tak jsem to zkoušel, a kód byl dokonce pomalejší. (Myslel jsem nejdřív, že bude třeba změnit program na mnoha místech, tak jsem s tím nechtěl nejdřív hned experimentovat, ale šlo to vcelku snadno.) Díky.
    14.11.2009 23:06 Jirka P.
    Rozbalit Rozbalit vše Re: zrychlení opakovaného volání virtuálních funkcí pomocí boost::bind
    Silně pochybuji - dokonce myslím, že zrychlení není možné, protože samotný boost::function při volání používá virtuální funkci.

    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.