Byla vydána pro lidi zdarma ke stažení kniha The Book of Remind věnovaná sofistikovanému kalendáři a připomínači Remind.
Grafický editor dokumentů LyX, založený na TeXu, byl vydán ve verzi 2.5.0. Oznámení připomíná 30. výročí vzniku projektu. Novinky zahrnují mj. vylepšení referencí nebo použití barev napříč aplikací, od rozhraní editoru po výstupní dokument.
F-Droid bannerem na svých stránkách a také v aplikacích F-Droid a F-Droid Basic upozorňuje na iniciativu Keep Android Open. Od září 2026 bude Android vyžadovat, aby všechny aplikace byly registrovány ověřenými vývojáři, aby mohly být nainstalovány na certifikovaných zařízeních Android. To ohrožuje alternativní obchody s aplikacemi jako F-Droid a možnost instalace aplikací mimo oficiální obchod (sideloading).
Svobodná historická realtimová strategie 0 A.D. (Wikipedie) byla vydána ve verzi 28 (0.28.0). Její kódový název je Boiorix. Představení novinek v poznámkách k vydání. Ke stažení také na Flathubu a Snapcraftu.
Multimediální server a user space API PipeWire (Wikipedie) poskytující PulseAudio, JACK, ALSA a GStreamer rozhraní byl vydán ve verzi 1.6.0 (Bluesky). Přehled novinek na GitLabu.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.2 a 20.04 OTA-12.
Byla vydána (Mastodon, 𝕏) nová stabilní verze 2.0 otevřeného operačního systému pro chytré hodinky AsteroidOS (Wikipedie). Přehled novinek v oznámení o vydání a na YouTube.
WoWee je open-source klient pro MMORPG hru World of Warcraft, kompatibilní se základní verzí a rozšířeními The Burning Crusade a Wrath of the Lich King. Klient je napsaný v C++ a využívá vlastní OpenGL renderer, pro provoz vyžaduje modely, grafiku, hudbu, zvuky a další assety z originální kopie hry od Blizzardu. Zdrojový kód je na GitHubu, dostupný pod licencí MIT.
Byl představen ICT Supply Chain Security Toolbox, společný nezávazný rámec EU pro posuzování a snižování kybernetických bezpečnostních rizik v ICT dodavatelských řetězcích. Toolbox identifikuje možné rizikové scénáře ovlivňující ICT dodavatelské řetězce a na jejich podkladě nabízí koordinovaná doporučení k hodnocení a mitigaci rizik. Doporučení se dotýkají mj. podpory multi-vendor strategií a snižování závislostí na vysoce
… více »Nizozemský ministr obrany Gijs Tuinman prohlásil, že je možné stíhací letouny F-35 'jailbreaknout stejně jako iPhony', tedy upravit jejich software bez souhlasu USA nebo spolupráce s výrobcem Lockheed Martin. Tento výrok zazněl v rozhovoru na BNR Nieuwsradio, kde Tuinman naznačil, že evropské země by mohly potřebovat větší nezávislost na americké technologii. Jak by bylo jailbreak možné technicky provést pan ministr nijak nespecifikoval, nicméně je známé, že izraelské letectvo ve svých modifikovaných stíhačkách F-35 používá vlastní software.
Tiskni
Sdílej:
este aspon jeden musi mat okuliare
hranaté - musí mít hranaté obroučky - jinak to nende ...
(při dostatečně volné definici)
class A:
"Trieda A"
class B(A):
"Trieda B"
class C:
"Trieda C"
object = B()
print('Premenna "object" - instancia typu B '+ ('je','neni')[not isinstance(object, A)] + ' typu A')
print('Premenna "object" - instancia typu B '+ ('je','neni')[not isinstance(object, B)] + ' typu B')
print('Premenna "object" - instancia typu B '+ ('je','neni')[not isinstance(object, C)] + ' typu C')
Nie som pythonista ale skúsil som si tento príklad a mám pocit že to funguje presne ako som očakával.
vo výpise mám:
Premenna "object" - instancia typu B je typu A
Premenna "object" - instancia typu B je typu B
Premenna "object" - instancia typu B neni typu C
var list = new List<object>() { new Type1(), new Type2() };
neni polymorfizmus? Je to polymorfizmus dokonca sú tam hneď 2 druhy polymorfizmu, inkluzívny a parametrický (v prípade kolekcie List). Objekt typu Type1 je zároveň aj typom object a tým pádom ho môžem vložiť do generickej kolekcie typu objekt.
var numbers = new ArrayList();
numbers.Add(5);
numbers.Add(true);
numbers.Add("xxx");
alebo správne, použijem parametrický polymorfizmus, vďaka ktorému mám istotu že do zoznamu sa vloží iba číslo. ak sa do zoznamu vloží hodnota iného typu napr. boolean tak sa program nepreloží a kompilátor vyhodí chybu. A to šetrí kopec roboty a teda aj času, niekedy až 10 násobne.
var numbers = new List<int>();
numbers.Add(5);
numbers.Add(true); // na tomto riadku mi kompilátor vyhodí chybu
numbers.Add("xxx");
Prečítal som si a nesúhlasím. Ale nemám chuť tu ďalej o tom flamovať. Nenapísali ste sem ani vašu definíciu polymorfizmu. A bez toho aby sme si zadefinovali pojmy sa jednoducho diskutovať nedá. Ja požívam tie definície ktoré používa mainstream. Vpodstate ste mi ani neoponovali pretože váš príspevok sa netýkal priamo polymorfizmu. Ak vidíte problém v OOP tak ja vám poviem v čom je problém. Hlavný problém OOP je v tom že ho ste ho nepochopili, tak ako ste nepochopili výhody typovej bezpečnosti, atď. Na to aby ste zistili aké výhody OOP v praxi prináša ho musíte používať dennodenne niekoľko rokov v súčinnosti s poriadnym IDE a Frameworkom. Bez toho toho aby ste sa programovaním niekoľko rokov živili budete vždy len programátor teoretik.
Tyto příklady jsou ale definice typu (např v Javě Generics) pro lepší typovou kontrolu, nikoliv polymorfismus. Toto:
var numbers = new ArrayList();
v podstatě odpovídá:
var numbers = new ArrayList<Object>();
a tedy je to seznam objectů a proto do toho můžeš uložit všechno co je object. Zatímco toto
var numbers = new List<int>();
Je seznam intů (vynechme teď, že v Javě není int object a že správně by mělo být Integer).
ArrayList<Object> nebo List<int> jsou příklady polymorfismu.
alebo správne, použijem parametrický polymorfizmus, vďaka ktorému mám istotu že do zoznamu sa vloží iba číslo. ak sa do zoznamu vloží hodnota iného typu napr. boolean tak sa program nepreloží a kompilátor vyhodí chybu. A to šetrí kopec roboty a teda aj času, niekedy až 10 násobne.Takze vlastne tou definici vstupniho typu standardizujes interface ne? Takze mu davas za pravdu.
Ten rozpor vychází z toho, že při návrhu programu se orientuju na toky dat vrámci systému a nikoliv na použité typy. V obvyklém pojetí OOP jsou však první myšlenkou definice použitých typů, naneštěstí často i poslední. Dalo by s říct, že nejdříve navrhnu instance objektů a jejich vzájemné propojení, přitom však jejich typ kolikrát ani neřeším – je to jen nezajímavý implementační detail.To je (IMHO) problém toho, že takové "obvyklé pojetí" OOP funguje dobře jen na velmi nižší úrovni abstrakce (v podstatě se týká jen implementace). Nějaké pokusy o vyšší úrovně jsou (např. EJB, SOA), ale nedá se říci že by to byl přesvědčivý úspěch (pokud vůbec).
Problém týchto mladých programátorov je, že nedokážu priznať, že sa mýlia a majú medzery vo vzdelaní. A za každú cenu sa snažia dokázať že sa mýli ich oponent. A najhoršie je že obhajujú, neobhájiteľné. Tvrdia že čierna je v skutočnosti biela a takýmto štýlom sa nedá diskutovať.Mně by zajímalo, jestli na tohle existuje nějaký recept, jak tomu člověku dát najevo, že je kokot a kecá píčoviny, aniž by ho to nasralo, urazilo a utvrdilo v tom, že kokot jsem já.