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.).
ahoj jdes na to spravne, chybka bude asi nekde schovana v kodu, ktery jsi sem nenapsal, to co jsi napsal predava referenci na objekt T2, je to tedy parametr predavany odkazem, pokud se jedna o nedynamickou instanci, kterou chces predavat hodnotou, muzes pouzit normalni metoda(T2 objekt) ... tedy treba
class T1 {
void metoda(T2 objekt) { ... }; // hodnotou
void metoda(T2 &objekt) { ... }; // preda nedynamickou instanci odkazem
void metoda(T2 *objekt) { ... }; // preda ukazatel hodnotou, tedy dynamicky vytvoreny objekt odkazem
};
obecne, nejsou zadna omezeni, odkazem muzes predat jakoukoliv tridu....pokud chces predavat hodnotou, napada me jen jedno omezeni, dana trida od ktere je objekt odvozen nesmi byt abstraktni (nesmi obsahovat rize virtualni metody ani dedit nedodefimovane rize virtualni metody)
Třeba
pokud chces predavat hodnotou, napada me jen jedno omezeni, dana trida od ktere je objekt odvozen nesmi byt abstraktni-- abych mohl předávat instanci jako parametr nějaké metodě, logicky přece nemůže být třída dané instance abstraktní, jelikož jsem ji přece *instancioval*
achjo clovicku, neni to zmatene, poradne si to prectete....
1) ja NEPISU ze nemuze!!! ..jen je to ponekud kostrbate pro jednoduchy projektit o dvou tridach. Samozrejme ze predavat dynamickou promennou referenci je uplne bezne, dokonce casto, pokud se u projektu pracuje s rozsahlimi objekty, voli se parametry metod jako konstantni, predavane referenci, kdezto instance se vytvareji dynamicky
2) nemuze, ale ta instance v momente deklarovani metody s velkou pravdepodobnosti NEEXISTUJE, tedy neprojde to pres onu deklaraci metody
3) kdyz uz jsme u toho slovickareni se slovem staticky bych si tolik nezahraval, pouzival bych radeji dynamicky/nedynamicky nebo alokovany na halde/ alokovany na zasobniku , protoze pod statickou instanci si lze predstavit, jak jiste vite ledaccos
Třeba mě jako začátečníka by to asi zmátlo.
sorry, myslel jsem ze chce obecne vedet zda existuje omezeni pro parametry metod, pak se stejne ukazalo, ze slo o cross-include, takze jsi mel vlastne pravdu s tim ze kod napovi
obecne, nejsou zadna omezeni, odkazem muzes predat jakoukoliv tridu....pokud chces predavat hodnotou, napada me jen jedno omezeni, dana trida od ktere je objekt odvozen nesmi byt abstraktni (nesmi obsahovat rize virtualni metody ani dedit nedodefimovane rize virtualni metody)
To je... nějak divně napsané. Nevím, jakou roli by v tom mohly hrát virtuální metody, ani jak vypadá ne-ryze virtuální metoda. Jinak odkazem se dají předávat samozřejmě i dynamické instance. Ono vůbec o C++ si bude lepší přečíst nějakou pořádnou knížku, třeba od Stroustrupa, než sbírat moudra po webu.
Když se předává hodnotou, musí se dát pozor, aby funkce (metoda) nepřijímala jen předka instance, kterou ji chceš předat. Ty data, která jsou v instanci "navíc" oproti tomu předkovi by mohly zmizet. Je to ten samý důvod, proč zachytávat výjimky odkazem a proč do STL kontejnerů nedávat přímo objekty různých odvozených tříd. Asi by to mělo i vyprodukovat nějaký warning, ale teď v noci to zkoušet nebudu...
mas pravdu, to je dobry postreh, to me nenapadlo ...btw: ja pisu hodne shared library, ktere casto obsahujou tridy, ktere budou pouzivany "zvenci" v pripade napriklad nejakeho obecneho, abstraktniho rendereru, s vetsim pocet rize virtualnich metod se mi semtam stane ze zapomenu v jeho potomkovi nejakou dodefinovat, predam jeho instanci hodnotou (ale instance bude fyzicky deklarovana az v aplikaci pouzivajici knihovnu), tak proto me to napadlo a psal jsem o tom, samozrejme pred prekladem to zarve, takze zadnej kolosalni problem
obecne, nejsou zadna omezeni, odkazem muzes predat jakoukoliv tridu....pokud chces predavat hodnotou, napada me jen jedno omezeni, dana trida od ktere je objekt odvozen nesmi byt abstraktni (nesmi obsahovat rize virtualni metody ani dedit nedodefimovane rize virtualni metody)
Asi bych jeste dodal (jestli si to dobre pamatuju), ze je potreba, aby mela ta trida copy constructor (ano muze byt i defaultni, ale to obcas neni to co chcete)...
Rozhodně je jednodušší opravit ti konkrétní chyby než odpovídat na obecné dotazy.
#ifndef T1_H
#define T1_H
#include <systemove_knihovny>
#include "T2.h"
class T1 {
nejake vlastnosti;
public:
T1();
~T1();
};
#endif
A soubor T2.h vypadá takhle:
#ifndef T2_H
#define T2_H
#include <kni.h.ovny>
#include "T1.h"
class T2 {
nejake vlastnosti;
public:
T2();
T2(T1 &t1); // TADYTEN ŘÁDEK DĚLÁ PROBLÉM
T2(int i1, int i2, int i3, int i4, bool b1 = false, bool b2 = true);
T2(int i1, int i2, bool b1 = false, bool b2 = true);
~T2();
dalsi metody();
...
};
#endif
Pokud se toto pokusím zkompilovat, dostanu error: expected `)' before ‘&’ token na řádku, který jsem označil komentářem (tzn. přímo toto, bez ohledu na to, jestli je implementace v .cpp souboru hotová nebo ne. Stejně se to chová i při pass-by-address nebo obyčejném pass-by-value.
T1 &t1 dát class T1 &t1.
Což mě ovšem překvapuje - měl jsem za to, že v C++ se název třídy bere jako název typu - při vytváření proměnných to tak funguje, proč to je v deklaraci funkce jinak?
podle meho nazoru to mozna mohlo byt tim, ze jsi includoval T1.h v T2.h a obracene T2.h v T1.h, pokud si pamatuji pri takovymhle krizovym include byva problem s rozpoznanim typu, resenim je pouzit v jednom z h souboru Doprednou deklaraci, napriklad v T2.h pred deklaraci T1: class T1;.....class v deklaraci funkce jsem nepouzival, dovolil bych si spekulovat ze se jedna o ono doprednou deklaraci v hlavicce metody, radeji na to nekam mrkni
class T1;. Nejlépe nad řádek s class T2 {.
include a vyřešit se dá použitím dopředné deklarace.
Jinak obecně v případech, kdy ve třídě A potřebuješ například jen ukazatel na objekt nějaké jiné třídy B, je docela zbytečné před samotnou deklarací A includovat celý hlavičkový soubor třídy B. Kompilátor se spokojí s tím, že ho dopřednou deklarací ujistíš o tom, že třída B bude definovaná prostě jenom někde jinde. Preprocessor tak nebude muset natahovat celý hlavičkový soubor a ušetří to docela dost práce (v opravdu velikém projektu by se spousta závislostí mezi soubory už mohla docela dost projevit na době kompilace).
Tiskni
Sdílej: