Vojenské zpravodajství (VZ) se v březnu zapojilo do mezinárodní operace proti aktivitám hackerské skupiny APT28, která je spojovaná s ruskou vojenskou zpravodajskou službou GRU a která přes slabě zabezpečené routery prováděla kybernetické útoky na státní a další organizace v ČR i zahraničí. Operaci vedl americký Federální úřad pro vyšetřování (FBI) a jejím cílem bylo odebrat útočníkům přístup k napadeným zařízením a ty následně … více »
Tvůrcem nejpopulárnější kryptoměny bitcoin, který se skrývá za pseudonymem Satoši Nakamoto (Satoshi Nakamoto), je britský kryptograf Adam Back. Na základě vlastní investigativní práce to tvrdí americký deník The New York Times (NYT). Několik indicií podle autorů jasně ukazuje na to, že Back a Nakamoto jsou stejný člověk. Jde mimo jiné o podobný odborný a osobnostní profil či totožné chyby a manýry v psaném projevu.
Google Chrome 147 byl prohlášen za stabilní. Nejnovější stabilní verze 147.0.7727.55 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Vylepšeny byly také nástroje pro vývojáře. Přehled novinek v Chrome DevTools 145 až 147 také na YouTube.
Vývojáři z Laboratoří CZ.NIC vydali nové verze aplikací Datovka (Datovka 4.29.0, Mobilní Datovka 2.6.2). V případě desktopové verze přibyly možnosti projít všechny uložené zprávy, zkontrolovat časy expirací časových razítek a přerazítkovat datové zprávy, které lze v ISDS přerazítkovat. Novinkou je také možnost vytahovat myší ze seznamu ZFO soubory datových zpráv, tento úkon jde udělat i pomocí tlačítek Ctrl+C. Nová verze Mobilní Datovky přináší jen drobné úpravy.
MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.28.0. Z novinek lze vypíchnout novou třídu machine.CAN.
Michael Meeks, CEO společnosti Collabora, na apríla oznámil, nebyl to ale apríl, že nadace The Document Foundation zastřešující vývoj kancelářského balíku LibreOffice vyloučila ze svých řad všechny zaměstnance a partnery společnosti Collabora, tj. více než třicet lidí, kteří po mnoho let přispívali do LibreOffice. Nadace The Document Foundation po několika dnech publikovala oficiální vyjádření. Přiznává pochybení při zakládání
… více »Protože je už po aprílu, můžou strahováci opět zveřejnit program další Virtuální Bastlírny, aniž by připravená témata působila dojmem, že jde o žert. Vězte tedy, že v úterý 14. dubna (změna!!!) od 20:00 proběhne VB, kde se setkají bastlíři, technici, učitelé i nadšenci do techniky a kde i vy se můžete zapojit do družného hovoru, jako by všichni seděli u pomyslného piva. Co mají bastlíři tento měsíc na srdci? Pravděpodobně by nás musel zasáhnout
… více »Byla vydána verze 26.1 aneb čtvrtletní aktualizace open source počítačového planetária Stellarium (Wikipedie, GitHub). Vyzkoušet lze webovou verzi Stellaria na Stellarium Web.
VOID (Video Object and Interaction Deletion) je nový open-source VLM model pro editaci videa, který dokáže z videí odstraňovat objekty včetně všech jejich fyzikálních interakcí v rámci scény (pády, kolize, stíny...) pomocí quadmaskingu (čtyřhodnotová maska, která člení pixely scény do čtyř kategorií: objekt určený k odstranění, překrývající se oblasti, objektem ovlivněné oblasti a pozadí scény) a dvoufázového inpaintingu. Za projektem stojí výzkumníci ze společnosti Netflix.
Design (GitHub) je 2D CAD pro GNOME. Instalovat lze i z Flathubu. Běží také ve webovém prohlížeči.
#include <string>
#include <iostream>
class Base {
public:
std::string x;
int y;
Base(std::string x_, int y_): x(x_), y(y_) {}
Base(Base &&b): x(std::move(b.x)), y(b.y) {}
virtual ~Base() {}
virtual void do_something() = 0;
virtual void turn_to_a() {}
};
class B;
class A: public Base {
public:
A(B &&b);
A(std::string x_, int y_): Base(x_, y_) {}
void do_something() override
{
std::cout << "I am 'A'. x = " << x << ", y = " << y << "\n";
}
};
class B: public Base {
public:
B(std::string x_, int y_): Base(x_, y_) {}
void do_something() override
{
std::cout << "I am 'B'. x = " << x << ", y = " << y << "\n";
}
void turn_to_a() override
{
static_assert(sizeof(A) == sizeof(B), "must be the same size");
B tmp(std::move(*this));
this->B::~B();
new (this) A(std::move(tmp));
}
};
A::A(B &&b): Base(std::move(b)) {}
int main()
{
Base *b = new B("life, universe and everything", 42);
b->do_something();
b->turn_to_a();
b->do_something();
delete b;
}
Řešení dotazu:
union?
bool is_a;. A potom v kazdy metode testoval jestli je flag nastaveny, ale prijde me ze mit to oddeleny je o neco cistsi.
.
Dejme tomu ze mam 2 tridy - A a B. Obe dedi z tridy Base. Nepridavaji zadne promenne, jen predefinuji virtualni funkce. Program nacita data a vetsinou z nich chce vytvorit tridu B. Obcas ale A a problem je ze tuto informaci se dozvi az pozdeji. Kdyz se dozvi ze vlastne potrebuje A tak nechci aby musel alokovat novou pamet, ani aby musel zpetne menit pointery ktere uz ukazuji na B.Začalo to hezky, skoro jako v pohádce: Žily byly dvě sestry, jedna staříkova, druhá stařenčina ... ... ale zápletka na sebe nenechala dlouho čekat. Pokud program chce "většinou" vytvořit třídu B, ale někdy později ji chce vyměnit za A, tak najednou se po nás chce zajistit dynamické chování ve statickém světě dědičnosti tříd. Prostě z jezevčíka mávnutím kouzelné hůlky udělat dobrmana. Vždyť je to přeci také pes. Použití operátoru new s umístěním je ale stejné jako nahánění jezevčíka s chirurgickým skalpelem v ruce. Když se na to podívám z druhé strany, tak vlastně nepotřebuji předělávat jezevčíka na dobrmana, ale chci jen naučit psa kousat jako dobrman, aby mi nikdo nechodil po dvorku. Pokud nejsem psí zubař, tak mohu tedy skalpel s klidem zahodit
.
Na všechno mi stačí jedna hlavní třída a to případné "kousání" si zajistíme až podle situace.
#include <iostream>
enum StrategyType
{
A,
B
};
class Strategy
{
protected:
std::string* x;
int* y;
public:
void setOptions(std::string* _x, int* _y) { x = _x; y = _y; }
virtual void doSomething() = 0;
};
class StrategyA : public Strategy
{
virtual void doSomething()
{
std::cout << "I am 'A'. x = " << *x << ", y = " << *y << std::endl;
}
};
class StrategyB : public Strategy
{
virtual void doSomething()
{
std::cout << "I am 'B'. x = " << *x << ", y = " << *y << std::endl;
}
};
class Base
{
private:
std::string x;
int y;
Strategy* strategy;
public:
Base(std::string x_, int y_): x(x_), y(y_), strategy(NULL) {}
~Base() { delete strategy; }
void doSomething()
{
strategy->doSomething();
}
void setStrategy(StrategyType type)
{
if (strategy)
delete strategy;
if (type == A)
strategy = new StrategyA();
else if (type == B)
strategy = new StrategyB();
strategy->setOptions(&x, &y);
}
};
int main()
{
Base base("life, universe and everything", 42);
base.setStrategy(B);
base.doSomething();
// ...
base.setStrategy(A);
base.doSomething();
return 0;
}
Oproti zadání je možné měnit strategie nejen z B na A, ale i zpět a navíc opakovaně.
template<typename T>
class Wrap
{
public:
T* new_() { return new(this) T();}
void delete_() { ((T*)this)->~T(); }
unsigned char data[sizeof(T)];
};
class Base
{
public:
Base() {}
virtual ~Base() {}
virtual int getType() const = 0;
int a;
int b;
};
class A : public Base
{
public:
A() {}
virtual ~A() {}
virtual int getType() const { return 1; }
};
class B : public Base
{
public:
B() {}
virtual ~B() {}
virtual int getType() const { return 2; }
};
union Union
{
template<typename T>
T* as() { return (T*)this; }
Wrap<A> a;
Wrap<B> b;
};
int main(int argc, char* argv[])
{
Union u;
u.a.new_();
printf("%d\n", u.as<Base>()->getType());
u.a.delete_();
u.b.new_();
printf("%d\n", u.as<Base>()->getType());
u.b.delete_();
return 0;
}
Tiskni
Sdílej: