Proběhla hackerská soutěž Pwn2Own Ireland 2025. Celkově bylo vyplaceno 1 024 750 dolarů za 73 unikátních zranitelností nultého dne (0-day). Vítězný Summoning Team si odnesl 187 500 dolarů. Shrnutí po jednotlivých dnech na blogu Zero Day Initiative (1. den, 2. den a 3. den) a na YouTube.
Byl publikován říjnový přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Pracuje se na podpoře M3. Zanedlouho vyjde Fedora Asahi Remix 43. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.
Iniciativa Open Device Partnership (ODP) nedávno představila projekt Patina. Jedná se o implementaci UEFI firmwaru v Rustu. Vývoj probíhá na GitHubu. Zdrojové kódy jsou k dispozici pod licencí Apache 2.0. Nejnovější verze Patiny je 13.0.0.
Obrovská poptávka po plynových turbínách zapříčinila, že datová centra začala používat v generátorech dodávajících energii pro provoz AI staré dobré proudové letecké motory, konvertované na plyn. Jejich výhodou je, že jsou menší, lehčí a lépe udržovatelné než jejich průmyslové protějšky. Proto jsou ideální pro dočasné nebo mobilní použití.
Typst byl vydán ve verzi 0.14. Jedná se o rozšiřitelný značkovací jazyk a překladač pro vytváření dokumentů včetně odborných textů s matematickými vzorci, diagramy či bibliografií.
Specialisté společnosti ESET zaznamenali útočnou kampaň, která cílí na uživatele a uživatelky v Česku a na Slovensku. Útočníci po telefonu zmanipulují oběť ke stažení falešné aplikace údajně od České národní banky (ČNB) nebo Národní banky Slovenska (NBS), přiložení platební karty k telefonu a zadání PINu. Malware poté v reálném čase přenese data z karty útočníkovi, který je bezkontaktně zneužije u bankomatu nebo na platebním terminálu.
V Ubuntu 25.10 byl balíček základních nástrojů gnu-coreutils nahrazen balíčkem rust-coreutils se základními nástroji přepsanými do Rustu. Ukázalo se, že nový "date" znefunkčnil automatickou aktualizaci. Pro obnovu je nutno balíček rust-coreutils manuálně aktualizovat.
VST 3 je nově pod licencí MIT. S verzí 3.8.0 proběhlo přelicencování zdrojových kódů z licencí "Proprietary Steinberg VST3 License" a "General Public License (GPL) Version 3". VST (Virtual Studio Technology, Wikipedie) je softwarové rozhraní pro komunikaci mezi hostitelským programem a zásuvnými moduly (pluginy), kde tyto moduly slouží ke generování a úpravě digitálního audio signálu.
Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 25.10. Podrobný přehled novinek v poznámkách k vydání.
V Londýně probíhá dvoudenní Ubuntu Summit 25.10. Na programu je řada zajímavých přednášek. Zhlédnout je lze také na YouTube (23. 10. a 24. 10.).
dobrý den,
Měl bych dotaz.
Vytvořil jsem si jednu třídu CZamestnanci a 2 potomky CVojak a COz.
vytvořil jsem si pole objektů třídy CZamestnanec :
CZamestnanec *lide[100];
nyní bych chtěl vytvářet objekty (potomky) CVojak a COz
pokud vsak vytvorim objekt takto : lide[0] = new CVojak tak objekt lide[0] je stále třídy CZamestanci.
Nevíte jak to udělat tak aby mohl vytvářet prvky pole třídy CVojak nebo COz podle toho jaky typ zrovna chci?
děkuji za odpověď
Disclaimer: v C++ som nikdy nič užitočné nenaprogramoval a vedomosti mám viacmenej len zo školy, takže tento komentár berte s rezervou.
K Tvojmu problému: pokiaľ viem, tak on to je CVojak, ale tým že k nemu pristupuješ cez typ CZamestnanec *, tak s ním môžeš robiť len ako s CZamestnancom. Keď chceš volať metódy zdedených tried, tak tie metódy musia byť virtual a keď chceš prístupiť k dátam toho CVojaka, tak to jedine, že si ten smerník predtým pretypuješ.
#include <iostream>
using namespace std;
class Zamestnanec{
public:
void setNazev(){cout << "Nazev";}
void setJidlo(){cout << "Jidlo";};
};
class Debil : public Zamestnanec{
public:
void setZadrz(){cout << "Zadrz";};
};
class Kokot : public Zamestnanec{
public:
void setOjeb(){cout << "Ojeb";};
};
int main(int argc, char** argv)
{
Zamestnanec *pole[100];
pole[0] = (Debil*) new Debil();
pole[1] = new Kokot();
((Debil*)pole[0])->setZadrz();
return 0;
}
Děkujimoc. Zachránil jsi mi život...Tohle funguje bezvadně 
To možná jo, ale já jsem příliš velkej začátečník abych věděl co to je
. Tak například vector by se dal použít takto:
#include <iostream>
#include <vector>
using namespace std;
class Zamestnanec{
public:
void setNazev(){cout << "Nazev";}
void setJidlo(){cout << "Jidlo";};
};
class Debil : public Zamestnanec{
public:
Debil(int d){
this->data=d;
}
void setZadrz(){cout << this->data;}
private:
int data;
};
class Kokot : public Zamestnanec{
public:
void setOjeb(){cout << "Ojeb";};
private:
int data;
};
int main(int argc, char** argv)
{
vector<Zamestnanec*> pole;
pole.push_back((Debil*) new Debil(5));
pole.push_back(new Kokot());
((Debil*)pole.at(0))->setZadrz();
return 0;
}
Výhodou je to že nejsi omezenej na staticky určený počet zaměstnancú.
. Třeba bude mít štěstí
class Zamest {
public:
virtual void setNazev() = 0;
virtual int plat() = 0;
void spolecne_veci(parametry..);
}
class Programator : public Zamest{
public:
void setNazev() { cout << "aaaaaaaaa"; }
int plat() { return 10000000; }
.......
}
class Uklizecka : public Zamest {
public:
void setNazev() { cout << "bbbbbbb"; }
int plat() { return 5; }
.........
}
............
Zamest *pole[100];
pole[0] = new Uklizecka();
......
Takto bych to řesil já
Ach jo, jak vidim na blbou otazku, blbe odpovedi... Proboha lidi, kdyz uz se pta zacatecnik, tak mu poradte tak, aby mu to alespon k necemu bylo!
Pokud bych se mel drzet zadani a prihlednu ke stavajicim odpovedim, tak to uz muzete rovnou pouzit toto (radsi explicitne rikam: TAKTO NE!):
void* pole[SIZE]; pole[0] = new Jenicek; pole[1] = new Marenka; ((Jenicek*) pole[0])->vidimSvetylkoVDali((*Marenka)pole[1]);
Divim se, ze se nikdo nezeptal, jak a proc se k jednotlivym prvkum bude pristupovat. Pokud cilem je pouze volat virtualni metody prvku kontejneru, tak je naprosto zbytecne toto vubec resit. Pokud je nutne k jednotlivym prvkum pristupovat odlisne v zavislosti na jejich typu (predpokladam, ze jsou to ruzni potomci jednoho predka), tak to znamena spatny navrh a problem by mel byt vyresen jinak (s vyuzitim virtualnich metod).
Pokud se tomu opravdu nejde vyhnout, tak pro pretypovani predka na potomka se pouziva dynamic_cast (coz je dle meho nazoru prasarna, ale to je opravdu pouze muj nazor), ktere zarucuje typovou kontrolu, takze reseni by vypadalo asi takto.
class BlbecVlese { virtual ~BlbecVLese() {} };
class Jenicek : public BlbecVlese {...};
class Marenka : public BlbecVLese {...};
...
BLbecVLese* blbci[100];
blbci[0] = new Jenicek;
blbci[1] = new Marenka;
...
BlbecVLese* x = blbci[y]; //predpokladany predek
Jenicek* j = 0;
Marenka* m = 0;
if ( 0 != (j = dynamic_cast<Jenicek*>(x)) )
j->vylezNaStrom();
else if ( 0 != (m = dynamic_cast<Marenka*>(x)) )
m->pockejPodStromem();
else
{
jezibaba->sezer(x);
throw kosti;
}
...
Omlouvam se za konfliktni ton... Nechci rozpoutavat flame. Jen si myslim, ze rady zacatecnikovy by nemely byt ve smyslu: "chci udelat prasarnu => nekdo mi poradi jeste vetsi prasarnu jak to realizovat" 
. No tak když ono to svádělo mu tak poradit
. Jinak plně souhlasím stím že bude špatně navrženej už koncept. A dost pochybuji, že jako začátečník by se měl zaobírat věcmi jako dynamic_cast.
Tiskni
Sdílej: