Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-08-2007, 09:08   #1
AngeL)
Senior Member
 
L'Avatar di AngeL)
 
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
}});
}
mentre altri sono scritti così
Codice:
public static void main(String[] args) {
	//codice
}
ma cosa cambia? io ho sempre usato il secondo metodo e non ho mai avuto problemi

-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
	}
}
e così

Codice:
class MyProg {
	public static void main(String[] args) {
		JFrame frame = new JFrame();
		//codice
	}
}
voi quale usate e perchè?
AngeL) è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2007, 09:46   #2
Mixmar
Senior Member
 
L'Avatar di Mixmar
 
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 962
Quote:
Originariamente inviato da AngeL) Guarda i messaggi
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
}});
}
mentre altri sono scritti così
Codice:
public static void main(String[] args) {
	//codice
}
ma cosa cambia? io ho sempre usato il secondo metodo e non ho mai avuto problemi
Utilizzando il primo metodo puoi separare il thread principale della tua applicazione da quello demandato a disegnare la grafica swing: utilizzando il secondo metodo lo stesso thread svolge i due compiti, per cui può capitare, per esempio, che se la tua applicazione "si blocca" (perchè sta elaborando, per un errore, perchè in attesa dell'input di un utente eccetera), anche la grafica non venga ridisegnata, lasciandoti la ben nota finestrella "grigia" e vuota.
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
Mixmar è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2007, 12:20   #3
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
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);
}
Una parte del lavoro necessario alla proiezione della finestra viene eseguito da un Thread diverso dall'EDT (il thread di cui parlava Angel). In particolare, il thread Main esegue una mutazione di stato, cioè cambia il valore di un campo di window. L'EDT entra in gioco automaticamente perchè è tramite l'edt che vengono "prelevate" le risorse native che consentono di avere una finestra in AWT/Swing.

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!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 08:44   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da AngeL) Guarda i messaggi
ma cosa cambia?
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, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
Steam Machine: addio al 4K 60 fps. Valve...
Cosa aumenterà di prezzo dopo com...
Altro che 2028: Micron ha blindato prezz...
Come la tecnologia FWA connette i piccol...
Diesel Euro 5, scatta il divieto in quat...
Prime Day, HillMiles scende a 599€ e re...
OpenAI valuta di rinviare l'Ipo al 2027:...
Streaming e Pay TV: ogni famiglia italia...
Volkswagen, Blume prepara maxi-taglio da...
Trenitalia, attacco hacker: esposti alcu...
Adblock for YouTube, 11 milioni di insta...
Assassin's Creed Black Flag Resynced pot...
Gli USA dicono no a Polestar, sì a Volvo...
Steam Machine dovrebbe costare 700 dolla...
Microsoft 365, l'Antitrust apre un'istru...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 18:11.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v