Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
final EditText myEditText = (EditText)findViewById(R.id.myEditText);
Chápu že muselo dojít k přetypování z View na EditText protože findViewById vrací View a já potřebuju EditText. Kde se ale dá zjistit jaké typy jsou kompatibilní a lze je přetypovat ?
Dále mi neni jasný co je <String>
v tomto examplu :
final ArrayList<String> todoItems = new ArrayList<String>();
Díky za nakopnutí :)
Řešení dotazu:
test()
, o vraceném typu nic nevíte.
public Object test(int cislo) { if (cislo == 0) { return "nula"; } return 0; } String str = (String) test(0);V druhém případě jde o generika, novinku z Javy 5. Každopádně doporučuju sehnat nějakou učebnici Javy, dobrá je např. Učebnice jazyka Java od Pavla Herouta, novější vydáí už by měla zahrnovat i novinky v Javě 5.
Kde se ale dá zjistit jaké typy jsou kompatibilní a lze je přetypovat ?Přetypovat můžete co chcete na co chcete. Přetypování Vám ale "projde" jen v případě, že objekt je skutečně instancí dané třídy (nebo jejím potomkem). Pokud toto nebude splněno dostanete výjimku ClassCastException. To se týká přetypování objektů, přetypování primitivních typů je veskrze jiná věc.
Map map = (HashMap) new LinkedList();
OK, zdá se, že tohle chytne už překladač. Ale přeložíteMap map = (HashMap) new LinkedList();toto nepojde ani len skompilovat
Map m = (Map) new ArrayList();nebo
Map m = (HashMap) (Object) new ArrayList();a oboje podle očekávání vyhodí výjimku ClassCastException.
alebo predkom, co ale nema moc zmyselSmysl to má, pokud to třeba použijete v souvislosti s generiky (např. metodou
java.util.arrays.asList
).
LinkedList
na třídu HashMap
nepřetypujete, protože žádný objekt nemůže být zároveň typu HashMap
i LinkedList
. U rozhraní to možné je – můžete si vytvořit potomka ArrayList
, který bude zároveň typu Map
.
U toho konstruktoru je to sice vidět, že to přetypování je nesmysl, ale kompilátor zřejmě nezkoumá tenhle vyšší pohled. Pro kompilátor jsou to dva kroky – získání objektu typu ArrayList
(v tomto případě vytvořením nové instance) a v druhém kroku jeho přetypování. Když si místo toho představíte trochu jiný kód, ten už může normálně fungovat:
public ArrayList getArrayList() {…} Map m = (Map) getArrayList();
double
za předka int
).
Na druhou otázku také velmi zjednodušeně: jedná se o generiky a tento konkrétní zápis znamená, že v tom seznamu se mohou vykytovat pouze řetězce. Nic jiného tam nelze vložit a při čtení je automaticky deklarován typ String. Pozor na to, že generiky v Javě jsou zpracovávány jen na úrovní kompilátoru, ve výsledném kódu tam je deklarováno Object
a všude doplněno přetypování.
Tiskni
Sdílej: