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í.
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.
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.
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.
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].
V dubnu loňského roku představený poštovní klient Notion Mail bude 22. září ukončen.
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ší.
Společnosti OpenAI a Broadcom oznámily čip optimalizovaný pro AI pojmenovaný Jalapeño.
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.
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.
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:
boost::function při volání používá virtuální funkci.
boost::function při volání používá virtuální funkci.
Tiskni
Sdílej: