Byla vydána nová verze 24.04.28 s kódovým názvem Time After Time svobodného multiplatformního video editoru Shotcut (Wikipedie) a nová verze 7.24.0 souvisejícího frameworku MLT Multimedia Framework. Nejnovější Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
Byla vydána verze 5.30 dnes již open source operačního systému RISC OS (Wikipedie).
V aktuálním příspěvku na blogu počítačové hry Factorio (Wikipedie) se vývojář s přezývkou raiguard rozepsal o podpoře Linuxu. Rozebírá problémy a výzvy jako přechod linuxových distribucí z X11 na Wayland, dekorace oken na straně klienta a GNOME, změna velikosti okna ve správci oken Sway, …
Rakudo (Wikipedie), tj. překladač programovacího jazyka Raku (Wikipedie), byl vydán ve verzi #171 (2024.04). Programovací jazyk Raku byl dříve znám pod názvem Perl 6.
Společnost Epic Games vydala verzi 5.4 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.
Vyšlo Pharo 12.0, programovací jazyk a vývojové prostředí s řadou pokročilých vlastností. Krom tradiční nadílky oprav přináší nový systém správy ladících bodů, nový způsob definice tříd, prostor pro objekty, které nemusí procházet GC a mnoho dalšího.
Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.
Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.
Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.
class Hrac { private: QString * jmeno; QColor * barva; int * znak; int * body; public: Hrac(); Hrac(const Hrac &other); ~Hrac(); void nastavVlastnosti(QString jmeno, QColor barva, int znak, int body); int * zjistiZnak(); int * zjistiBody(); QColor * zjistiBarvu(); QString * zjistiJmeno(); TypHrace * zjistiTyp(); bool checkForVictory(); friend QDataStream &operator<<(QDataStream &out, Hrac &hrac); void serialize(QDataStream& ost); static Hrac unserialize(QDataStream& istr); };
Řešení dotazu:
serialize
a unserialize
, definice třídy se zdá v pořádku
QDataStream& operator <<(QDataStream &out, Hrac &hrac)
nemusí být friend, protože použije (měl by použít ) veřejnou metodu serialize
unserialize
by mělo vracet Hrac*, jinak se tam bude volat (zbytečně) copy konstruktor. Lepší by ale bylo vytvořit deserializační konstruktor explicit Hrac(QDataStream &str)
Btw. proč jsou tam ty dva int
y (znak
a body
) dynamicky alokované?
QDataStream &operator<<(QDataStream &out, Hrac &hrac) { return(out << hrac.jmeno->length()<< " " << hrac.jmeno->toAscii() << " " << hrac.barva << " " << hrac.znak << " " << hrac.body); } void Hrac::serialize(QDataStream &ost) { ost << this; } Hrac Hrac::unserialize(QDataStream &istr) { Hrac tmp; int delkajmena; QString jmeno; QColor barva; int znak; int body; istr >> delkajmena; //istr.readBytes() //? tmp.nastavVlastnosti(jmeno,barva,znak,body); return tmp; }Tu deserializaci udělám pomocí toho kontruktoru, takové řešení mě nenapadlo, díky. Dynamickou alokaci tam používám pro všechny objekty uvnitř tříd, neměl by v tom být žádný rozdíl ne? Kdyby vás zajímal ještě nějaký kus kódu, tak to celé mám na SVN pod http://code.google.com/p/pisqorky/source/browse/trunk#trunk/src .
Dynamickou alokaci tam používám pro všechny objekty uvnitř tříd, neměl by v tom být žádný rozdíl ne?I kdyby to byla pravda, tak proč se v takovym případě namáhat?
void Hrac::serialize(QDataStream &str) { str << *this->jmeno << *this->barva << *this->znak << *this->body; } void Hrac::unserialize(QDataStream &str) { str >> *this->jmeno >> *this->barva >> *this->znak >> *this->body; }resp. s konstruktorem:
Hrac::Hrac(QDataStream &str) : jmeno(new QString()) , barva (new QColor()) , znak (new int(0)) , body (new int(0)) { this->unserialize(str); }a pokud budou potřeba, tak přidat operátory
QDataStream& operator <<(QDataStream &str, Hrac &hrac) { hrac.serialize(str); return str; } QDataStream& operator >>(QDataStream &str, Hrac &hrac) { hrac.unserialize(str); return str; }
Tiskni Sdílej: