Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 211. sraz, který proběhne v pátek 19. září od 18:00 ve Studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Na srazu proběhne přednáška Jiřího Eischmanna o nové verzi prostředí GNOME 49. Nemáte-li možnost se zúčastnit osobně, přednáškový blok bude opět streamován živě na server VHSky.cz a následně i zpřístupněn záznam.
Microsoft se vyhnul pokutě od Evropské komise za zneužívání svého dominantního postavení na trhu v souvislosti s aplikací Teams. S komisí se dohodl na závazcích, které slíbil splnit. Unijní exekutivě se nelíbilo, že firma svazuje svůj nástroj pro chatování a videohovory Teams se sadou kancelářských programů Office. Microsoft nyní slíbil jasné oddělení aplikace od kancelářských nástrojů, jako jsou Word, Excel a Outlook. Na Microsoft si
… více »Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.
Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).
Byly publikovány informace o další zranitelnosti v procesorech. Nejnovější zranitelnost byla pojmenována VMScape (CVE-2025-40300, GitHub) a v upstream Linuxech je již opravena. Jedná se o variantu Spectre. KVM host může číst data z uživatelského prostoru hypervizoru, např. QEMU.
V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.
Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.
Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.
Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
Nevhodné pro prohlížení před dětmi nebo na veřejnosti.
Zobrazit komentářjsem ze sebe úplně udělal debilaTak to bys nám moh dělat mluvčího, splňuješ požadavky!
a vysranej zvuk by mohlo mit na triku to novy uzasny pulse-audio ...
no jestli tam mas voba najednou, tak by to mohlo bejt timne
a vysranej zvuk by mohlo mit na triku to novy uzasny pulse-audio ...ne
for(int i=0; i<64; i++) { final Integer cardIdx = Integer.valueOf(i); addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { setReverse(cardIdx); }); }Já osobně bych tedy nedělal celou novou komponenentu děděním od
JComponent
(to Component
je doufám překlep) a vyšel bych z některého potomka AbstractButton. Případně to celé dohromady udělal jako jednou komponentu která si bude vnitřní dělení na políčka dělat sama podle souřadnic, ušetří se starosti s layoutem.
Přijde vám taky, že swing a celkově java má naprosto otřesnou dokumentaci v porovnáním třeba s Qt?Většina dokumentací jsou bohužel v porovnání s Qt otřesné...
public class TestListener implements ActionListener { @Override public void actionPerformed(ActionEvent arg0) { ((MujObjekt)arg0.getSource()).get.....; } }Mela by se osetrit instance ale budiz. Karta PeXeSa
public class OneButton extends JButton { private int pos; private Icon icon; public int getPos() { return pos; } public Icon getIcon() { return icon; } public OneButton(int pos, Icon icon) { super(); this.pos = pos; this.icon = icon; } public void setPos(int pos) { this.pos = pos; } public void setIcon(Icon icon) { this.icon = icon; }A jeste budej potrebovat panel s Layout.
ublic class PexesoPanel extends JPanel { public class ActListener implements ActionListener { @Override public void actionPerformed(ActionEvent arg0) { // TODO Auto-generated method stub } } private static final long serialVersionUID = 6290986162807731571L; public PexesoPanel() { setLayout(new GridLayout(8,8)); for (int i=1;i<=64;i++){ OneButton ob = new OneButton(i,randomImage()); ob.addActionListener(new ActListener()); add(ob); } } protected Icon randomImage(){ return null; } }A nyni dodelat kostra by byla hlavne krasne obrazky kazdemu podle chuti.
final
proměnnou se to samozřejmě dá vyřešit (stačí jedna, nevím, proč si myslíte, ž ejich potřebujete 64). Tohle ale není problém Javy nebo Swingu, ale neznalosti základů objektového programování.
final
neznamená konstantu, ale proměnnou, jejíž hodnota je přiřazena při deklaraci – ale ta hodnota může být klidně dynamická, zjištěná až v době běhu. Takže třeba následující kód řeší váš problém přesně způsobem, o kterém v blogu tvrdíte, že nejde použít:
for (int karta = 0; karta < POCET_KARET, karta++) { final int poziceKarty = karta; addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { setReverse(poziceKarty); } } }Lepší než konstruovat 64 nebo kolik anonymních objektů se stejným kódem by mi ale přišlo udělat si neanonymní vnitřní třídu implementující listener, které byste pozici karty předával v konstruktoru (tím se zároveň vyhnete použití
final
). No a další možnost je použít jediný listener pro všechny karty, a pozici karty zjišťovat přímo z objektu, který událost vyvolal – z ActionEvent
si ten objekt můžete vytáhnout, no a ten objekt může být třeba vaše třída rozšiřující JPanel
, která bude mít jako vlastnost uvedenou právě pozici karty.
Ten váš kód je takový procedurální kód naivně zabalený do objektů, ten návrh s neanonymním listenerem alespoň vytkne společný kód, opravdu objektové je podle mne až to poslední, protože když tam pracujete s kartama, tak máte mít objekt karta
a ten má mít vlastnost pozice
, a ne že pozici budete zjišťovat bůhvíjakým způsobem.
Lepší než konstruovat 64 nebo kolik anonymních objektů se stejným kódem by mi ale přišlo udělat si neanonymní vnitřní třídu implementující listener, které byste pozici karty předával v konstruktoru (tím se zároveň vyhnete použití final
).
Jenom taková poznámka: tyto dvě možnosti jsou v podstatě equivalentní, akorát v případě anonymní třídy je ten field skrytý. To je také důvod, proč musí být ta proměnná final - ve skutečnosti se ta proměnná použije jen při vytváření instance anonymní třídy, kdy se hodnota zkopíruje.
To je také důvod, proč musí být ta proměnná final - ve skutečnosti se ta proměnná použije jen při vytváření instance anonymní třídy, kdy se hodnota zkopíruje.Kdyby se hodnota kopírovala při vytváření instance vnitřní třídy, nemusela by být ta zdrojová proměnná označená jako final, ne? Podle mne to
final
je naopak příznak toho, že se nekopíruje hodnota, ale použije se reference a tudíž změna hodnoty po vytvaření instance by změnila i hodnotu v té instanci vnitřní třídy.
Ona by teoreticky opravdu býtTo je také důvod, proč musí být ta proměnná final - ve skutečnosti se ta proměnná použije jen při vytváření instance anonymní třídy, kdy se hodnota zkopíruje.Kdyby se hodnota kopírovala při vytváření instance vnitřní třídy, nemusela by být ta zdrojová proměnná označená jako final, ne? Podle mne tofinal
je naopak příznak toho, že se nekopíruje hodnota, ale použije se reference a tudíž změna hodnoty po vytvaření instance by změnila i hodnotu v té instanci vnitřní třídy.
final
nemusela. Jenomže pak by se ukázalo, že při zápisu se změna neprojeví uvnitř a naopak, při zápisu uvnitř se změna neprojeví venku. A celá iluze "closure" by vybouchla.
Tím že proměnná musí být final
se můžeme tvářit, jako že to je opravdu ta proměnná - i když ve skutečnosti je to hodnota té proměnné.
Tiskni
Sdílej: