Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.
Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).
Microsoft zveřejnil zdrojový kód XAML Studia a uvolnil ho pod MIT licencí. XAML Studio je nástroj ze světa Windows, určený pro tvorbu uživatelského rozhraní aplikací pomocí XAML (Extensible Application Markup Language). Stalo se tak zhruba po osmi letech od prvního prohlášení Microsoftu, že se tento kód chystá zveřejnit.
TimeCapsule, 'časová kapsle', je jazykový model trénovaný výhradně na datech z určitých míst a časových období, aby se tak napodobila autentická slovní zásoba, způsob vyjadřování a názory dané doby. Na Hugging face jsou k dispozici modely natrénované na historických textech dostupných v oblasti Londýna mezi lety 1800 až 1875.
Radicle byl vydán ve verzi 1.6.0 s kódovým jménem Amaryllis. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.
Zemřel Scott Adams, tvůrce komiksových stripů Dilbert parodujících pracovní prostředí velké firmy.
Sdružení CZ.NIC vydalo novou verzi Knot Resolveru (6.1.0). Jedná se o první vydanou stabilní verzi 6, která je nyní oficiálně preferovanou a doporučovanou verzí, namísto předešlé verze 5. Více o Knot Resolveru 6 je možné se dočíst přímo v dokumentaci.
Byl vydán Linux Mint 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.
Wine bylo po roce vývoje od vydání verze 10.0 vydáno v nové stabilní verzi 11.0. Přehled novinek na GitLabu. Vypíchnuta je podpora NTSYNC a dokončení architektury WoW64.
Byl vydán Mozilla Firefox 147.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Firefox nově podporuje Freedesktop.org XDG Base Directory Specification. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 147 bude brzy k dispozici také na Flathubu a Snapcraftu.
Dobry den, ucim se pracovat s tridou Java SwingWorker. Pokud tuto tridu pouziji timto zpusobem, je vse ok, vse chapu.
private Document doc;
...
JButton button = new JButton("Open XML");
button.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
SwingWorker Document, Void worker =
new SwingWorker Document, Void () {
public Document doInBackground() {
Document intDoc = loadXML();
return intDoc;
}
public void done() {
doc = get();
}
};
worker.execute();
}
});
Co vsak nevim, je jak to udelat, pokud si chci vytvorit vlastni tridu v samostatnem souboru:
public class SwingWorkerChild extends SwingWorker
Tak jak potom mohu ziskat vyslednou hodnotu bez zamrznuti GUI? Pokud bych v event dispatch thread zavolal neco takoveho
SwingWorker swingWorker = new SwingWorkerChild(); swingWorker.execute(); String result = swingWorker.get();
Tak GUI zamrzne, protoze v okamziku volani metody get() neni hodnota jeste pripravena.
Ja bych prave potreboval tu vyslednou hodnotu vratit jako String, nebo alespon zmenit text na komponente JLabel, jenze k ni nemam ze tridy SwingWorkerChild pristup.
Doufam, ze jsem to vysvetlit srozumitelne co potrebuji, budu rad za jakekoliv navrhy, dekuji.
done().
Mám li například worker, který vrací složitě sestavovaný XML a který předpokládám použít mohokrát v různých třídách, kloním se jednoznačně k počkání na výsledek.To já také. Ale časovač není počkání na výsledek, ale opakované dotazování – dalo by se říci i otravování
– „už je výsledek hotov?“ Navíc tím budete stále blokovat AWT vlákno (i když nastavíte pro get() nějaký krátký čas), nebo kvůli tomu musíte zase vytvářet nové vlákno. Oním „čekáním“ pak strávíte zbytečně moc času – jak při programování, tak při samotném běhu programu.
Pokud se bude výsledek používat v mnoha třídách, vytvořil bych si k tomu interface pro posluchače událostí, a SwingWorker by v metodě done() pouze vyvolal příslušnou událost oznamující dokončení práce.
Otravování může zároveň kontrolovat průběh akce viz getProgressTo je lepší udělat tak, že se vytvoří posluchač, který naslouchá změně property
progress.
Nechapu kde je problem. Kdyz se pouzije SwingWorkerChild na miste puvodniho pouziti anonymni tridy tak se stane co?
done() „vědět“, kdy práce skončila. Takže pokud chcete uživatele informovat o tom, že probíhá nějaká akce a chcete mu umožnit ji např. přerušit, ještě před zavoláním execute() vytvoříte dialogové okno, kde bude nějaký nápis o tom, co právě probíhá, a tlačítko k přerušení. V metodě done() pak vypíšete výsledek zpracování a onen dialog uzavřete. Samozřejmě není nutné zobrazovat dialog, stačí třeba přesýpací hodiny (pak ale uživatel nemá možnost akci přerušit), nebo – pokud na dokončení nic jiného nezávisí – můžete nechat akci probíhat jen na pozadí a na konci třeba jen vypsat zprávu do stavového řádku. Ale pokud chcete získat výsledek, měl byste jej získávat právě v metodě done() nebo v kódu, který je touto metodou vyvolán. Případně také můžete použít blokující get(), který čeká jen určitou dobu – ale ani ten byste neměl volat z AWT vlákna.
Jinak v dokumentaci SwingWorkeru je použití myslím docela dobře popsáno.
Dekuji sice za vysvetleni, ale to co jste napsal je mi zname, dokumentaci jsem studoval i jsem studoval SwingWorker examples ruzne na internetu a VSUDE, kde vytvareli tridu ktera dedi od SwingWorker, tak ji meli jako vnitrni tridu te hlavni GUI tridy - tak to funguje, vse ok. Mne jde o to - kvuli prehlednosti - umistit tu tridu ktera dedi od SwingWorker do samostatneho souboru. Pak jiz nemuzu v jeji metode done() jednoduse zavolat neco takoveho:
promenna_GUI_tridy = get();
Chapu to tedy dobre, ze v tomto pripade je konvenci pouzit vnitrni tridy, abych prave zamezil tomuto problemu?
To prvni reseni jsem tedy zkusil implementovat nejak takto:
GUI trida:
public class SwingWorkerTest extends javax.swing.JFrame {
protected String result;
public void setResult(String result)
{
this.result = result;
}
private void jButton1ActionPerformed(java.awt.event.ActionEvent evt)
{
SwingWorker swingWorker = new SwingWorkerChild(this);
swingWorker.execute();
jLabel1.setText(result);
}
...
}
SwingWorker trida:
public class SwingWorkerChild extends SwingWorker String, Void
{
protected String result;
protected SwingWorkerTest GUIClass;
public SwingWorkerChild(SwingWorkerTest GUIClass)
{
this.GUIClass = GUIClass;
}
@Override
public String doInBackground()
{
try
{
Thread.sleep(4000);
} catch (InterruptedException ex)
{
ex.printStackTrace();
}
return "Hello" + " " + "there!";
}
@Override
public void done() {
try
{
GUIClass.setResult(get());
//System.out.println("Result = "+result);
} catch (InterruptedException ex)
{
ex.printStackTrace();
} catch (ExecutionException ex)
{
ex.printStackTrace();
}
}
}
Jenze jsem narazil na ten samy problem zde:
swingWorker.execute(); jLabel1.setText(result);
V momente kdy chci pouzit promennou result, tak ta jeste neni hotova a do JLable1 se ulozi prazdny text. Resenim by asi bylo z metody done() rovnou menit ten text na jLabel1 - tak jste to myslel?
Chtel bych se zeptat na to treti reseni, mohl byste prosim nacrtnou kostru jak by to pro tento pripad asi vypadalo? Dekuji
jLabel1.setText(result); přesuňte do metody public void setResult(String result).
No jasne, nechapu, ze me to nenapadlo, skoro se az stydim, ze jsem se na to ptal:)
...nebo použijte posluchače událostí – GUI třída bude posluchač a SwingWorker vyvolá příslušnou událost.
Muzete me prosim nasmerovat na nejaky navod/tutorial, kde je tady tento zpusob nejak prehledne popsan?
Nikde jsem ale nenasel, jakou udalost vyvola dokonceni te metody doInBackground(). Jakou udalost mam tedy v naslouchajici tride (GUItrida) odchytavat?
state, a volání setProgress() vyvolá událost o změně property progress. Pokud chcete volat událost při skončení práce, musíte si připravit nějakou událost sám a vyvolat ji v metodě done().
Ano, to jsem si myslel, ale prave jsem nikde nemohl najit zadny ukazkovy priklad, kde se vytvari, spousti a odchytava vlastni udalost - ani v tech odkazech vyse. Mohl byste mi sem prosim napsat kostru jak by to vypadalo nebo alespon odkazat na priklad?
WorkerFinishListener nebo bude mít anonymní nebo vnitřní třídu tohoto typu a zaregistruje si ji do MySwingWorkeru.
public interface WorkerFinishListener<T> {
public void finished(SwingWorker<T> worker);
}
public class MySwingWorker extends SwingWorker<T, V> {
private final List<WorkerFinishListener<T>> finishListeners = new LinkedList<WorkerFinishListener<T>>();
public void addFinishListener(WorkerFinishListener<T> listener) {
finishListeners.add(listener);
}
public void removeFinishListener(WorkerFinishListener<T> listener) {
finishListeners.remove(listener);
}
@Override
public void done() {
for (WorkerFinishListener<T> listener : finishListeners) {
listener.finished(this);
}
}
…
}
class MyForm extends JForm {
public void zacatekCinnosti() {
final MySwingWorker<WorkResult> worker = new MySwingWorker<WorkResult>();
worker.addFinishListener(
new WorkerFinishListener () {
public void finished(worker) {
try {
MyForm.this.setStatus("Hotovo. Výsledek je: "+worker.get().toString());
} catch (ExecutionException ex) {
MyForm.this.setStatus("Došlo k chybě. "+ex.getCause().getLocalizedMessage());
}
}
}
);
worker.execute();
}
…
}
Dekuji, uz jsem se k tomu postupne dopracovaval, ale Vas kod mi hodne pomohl. Mel bych jeste dotaz, proc pisete u definice toho interface i jinde <T> - myslel jsem ze toto se pouziva pouze v dokumentaci. Ani mi to IDE nechtelo vzit, tak jsem <T> vsude smazal a funguje to...
<T> je označení parametrizovaného typu, což je jedna část generik přidaných v Javě 5. Pokud to chcete používat, musíte kompilátoru i IDE říct, že jde o kód pro Javu verze 1.5 nebo 1.6. Pokud píšete v Javě 5 nebo vyšší (doporučuju, pokud nemáte nějaký vážný důvod zůstávat u 1.4; a Java 6 je lepší než pětka, jsou tam vylepšené některé věci ve Swingu a další), doporučuju generiky používat, zjednoduší se tím používání vašich tříd (není nutné přetypovávat návratové hodnoty apod.) a zároveň se zvýší typová bezpečnost v době překladu (např. pokud se do kolekce čísel pokusíte strčit String, a používáte správně generiky, ohlásí chybu už překladač, a ne že program spadne až za běhu když se pokusíte tím Stringem násobit).
Docela podrobný úvod do novinek Javy 5 napsal pan Pecinovský v knížce Java 5.0 – Novinky jazyka a upgrade aplikací, která je teď zdarma ke stažení. Zrovna generiky tam nejsou popsané úplně ve všech detailech, ale je tam toho víc, než si normální smrtelník přeje vědět
Dekuji moc za vysvetleneni, mam snad uz posledni dotaz. Proc tam vytvarime to vlastni rozhrani, slo by to i bez neho, ne?
Tiskni
Sdílej: