|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: May 2006
Città: Salerno
Messaggi: 936
|
[Java - Swing] Due dubbi
leggendo qualche spezzone di codice java su internet mi è venuto un dubbio:
alcuni codici in swing sono scritti così: Codice:
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() { public void run() {
//codice
}});
}
Codice:
public static void main(String[] args) {
//codice
}
![]() -secondo e ultimo sempre leggendo spezzoni di codice, ne ho visti così Codice:
class MyProg {
public static void main(String[] args) {
MyFrame f = new MyFrame();
}
}
class MyFrame extends JFrame {
public MyFrame() {
//codice
}
}
Codice:
class MyProg {
public static void main(String[] args) {
JFrame frame = new JFrame();
//codice
}
}
|
|
|
|
|
|
#2 | |
|
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 962
|
Quote:
In questo senso, il primo metodo è preferibile al secondo.
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
|
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
|
Direi quasi. Prendiamo un caso concreto. Apertura di una finestra.
Usando la prima versione: Codice:
public static void main() {
JFrame window = new JFrame("window");
window.setVisible(true);
}
L'inghippo sta nel fatto che la maggior parte del codice dei componenti AWT/Swing non è predisposto all'esecuzione concorrente. Tra l'altro, gli stati (cioè i campi) dei componenti Swing non garantiscono la visibilità inter-thread delle proprie mutazioni. Non sono volatile o final o AtomicX per intenderci. Se il Thread Main cambia lo stato di visibile a true e questo stato non è Thread-safe, allora esiste la possibilità che il Thread EDT trovi ancora il vecchio valore di visible. E' una possibilità e non una certezza. Possibile perchè il linguaggio di programmazione Java dichiara quando una certa operazione ha un effetto inter-thread e lascia mano libera negli altri casi. La concreta implementazione del linguaggio può poi dire che tutte le mutazioni sono sempre visibili ma è un dettaglio su cui non possiamo fare affidamento. Esiste anche una questione più grave. Il deadlock di cui parla Angel. E qui non dipende più dall'implementazione. Parte del codice di Swing/AWT, in particolare i LayoutManager, è sincronizzato: l'esecuzione di taluni blocchi è subordinata al controllo di un monitor. Un particolare incrocio di acquisizione dei monitor reciprocamente detenuti da due diversi Thread causa uno stallo sicuro del programma. Qualche tempo fa Sun espose il problema dello stallo usando il thread principale semplicemente per aprire una finestra che conteneva una JTable. Per questo motivo il secondo metodo: public static void main... EventQueue.invokeLater(... oppure SwingUtilities.invokeLater(... non è preferibile al primo ma è semplicemente esatto mentre il primo è errato. Ricordo che questo vincolo dell'esecuzione di codice all'interno dell'EDT, tramite invokeLater di EventQueue, deve essere rispettato in ogni caso in cui si voglia leggere o scrivere lo stato di un componente Swing proiettabile (cioè direttamente o indirettamente inserito in una finestra realizzata). Non solo nel main, quindi, ma anche in ogni altro punto del codice in cui non si possa dare per scontato che il Thread corrente sia l'EDT.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me! |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
http://java.sun.com/products/jfc/tsc.../threads1.html
http://java.sun.com/products/jfc/tsc.../threads2.html http://java.sun.com/products/jfc/tsc.../threads3.html I link rispondono a tutte le tue domande.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 14:42.





















