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 04:22 | Nová verze

    Po téměř třech letech od vydání verze 9 byla vydána nová verze 10 linuxové distribuce Mageia (Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 04:00 | Zajímavý software

    Nourish (GitHub) je nový správce oken pro Linux. Tradiční plochy nahrazuje nekonečným plátnem a posouváním a přibližováním. Využívá vlastní kompozitor pro Wayland s názvem y5. Videoukázka.

    Ladislav Hagara | Komentářů: 3
    27.6. 15:33 | Komunita

    Po 20 letech a 17 otevřených (open source) krátkých filmech Blender Studio oznámilo plán na svůj první celovečerní film. Cílem samozřejmě není jenom nový otevřený film, ale především vývoj a vylepšení otevřených nástrojů pro spolupráci napříč celým procesem a vytvoření otevřené příručky (playbook) pro filmovou produkci ve velkém měřítku s informacemi, které jsou obvykle dostupné pouze uvnitř komerčních studií, a pomoci tak nezávislým tvůrcům překonat technické a organizační bariéry.

    Ladislav Hagara | Komentářů: 0
    27.6. 05:00 | Nová verze

    Byla vydána nová verze 26.6.25 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
    26.6. 14:44 | IT novinky

    Apple bez varování odstranil ze svého obchodu sociální síť VKontaktě i další aplikace skupiny VK, jako je VK Music nebo VK Video [Novinky.cz].

    Ladislav Hagara | Komentářů: 18
    26.6. 14:22 | IT novinky

    V dubnu loňského roku představený poštovní klient Notion Mail bude 22. září ukončen.

    Ladislav Hagara | Komentářů: 3
    26.6. 04:33 | Komunita

    Konference OpenAlt 2026 hledá přednášející. Proběhne o víkendu 7. a 8. listopadu na půdě Fakulty informačních technologií VUT v Brně. Témata konference jsou: Otevřený a svobodný software, IoT a Hnutí tvůrců, Vzdělávání, Bezpečnost a soukromí, Otevřená společnost, komunity a data, OpenMobility a další.

    Ladislav Hagara | Komentářů: 0
    26.6. 04:22 | IT novinky

    Společnosti OpenAI a Broadcom oznámily čip optimalizovaný pro AI pojmenovaný Jalapeño.

    Ladislav Hagara | Komentářů: 0
    25.6. 20:22 | Nová verze

    Deno (Wikipedie), běhové prostředí (runtime) pro JavaScript, TypeScript a WebAssembly, bylo vydáno v nové verzi 2.9. Hlavní novinkou je deno desktop pro převod Deno projektu na desktopovou aplikaci. Jedná se o alternativu k frameworkům Electron nebo Tauri.

    Ladislav Hagara | Komentářů: 2
    25.6. 15:44 | IT novinky

    Od zítra jsou Datové schránky oficiálně na nové adrese datovka.gov.cz. Adresa mojedatovaschranka.cz zůstává funkční do 27. srpna 2026, následně budou uživatelé automaticky přesměrováni na datovka.gov.cz.

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (7%)
     (2%)
     (17%)
     (31%)
     (4%)
     (6%)
     (2%)
     (16%)
     (26%)
    Celkem 2005 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    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: 213×
    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.