Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-05-2004, 12:01   #1
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
JAVA: eccezioni ingestibili

Ho costruito un JFrame con Java che contiene al suo interno, tra le altre cose, un JTree.

Siccome devo aggiornare periodicamente la visualizzazione di questo frame ho costruito un apposito Thread con questo codice

Codice:
class Refresher extends Thread{
  TopicNameSpaceFrame ilFrameDaAggiornare;

  public Refresher(TopicNameSpaceFrame a){ilFrameDaAggiornare=a;}

  public void run(){
    this.setPriority(Thread.MIN_PRIORITY);
    try{
      while(true){
        Thread.sleep(1000 * 10);
        /*codice vario*/
          ilFrameDaAggiornare.jTree.updateUI();
      }
    }catch(Exception e){/* qui non entra */}
  }
Il codice fa quello che deve fare, solo che, puntualmente ogni 10 secondi (solo se il frame è visibile e solo se la riga in grassetto è presente nel codice) mi lancia una NullPointerException ke nn riesco a gestire e guardando lo stackTrace(ke ora nn posso postare ) vedo ke l'eccezione occorre solo in classi presenti in java.awt e in javax.swing e in nessuna classe del mio package.

Come faccio a gestirla o a evitarla?

Ultima modifica di Molz : 28-05-2004 alle 12:20.
Molz è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2004, 12:32   #2
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
non capisco, anche se NullPointerException discende da RuntimeException il catch dovrebbe intercettarla.

Sei sicuro arrivi dal codice dentro il try?
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2004, 12:42   #3
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
Si si.

Come dicevo le eccezioni nn occorrono nel mio codice ma solo nelle classi di java.awt e di javax.swing
Se riesco posto lo stack trace dell'eccezione.
Molz è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2004, 12:47   #4
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
Eccolo

java.lang.NullPointerException
at javax.swing.plaf.basic.BasicTreeUI.paint(Unknown Source)
at javax.swing.plaf.metal.MetalTreeUI.paint(Unknown Source)
at javax.swing.plaf.ComponentUI.update(Unknown Source)
at javax.swing.JComponent.paintComponent(Unknown Source)
at javax.swing.JComponent.paint(Unknown Source)
at javax.swing.JComponent.paintWithOffscreenBuffer(Unknown Source)
at javax.swing.JComponent.paintDoubleBuffered(Unknown Source)
at javax.swing.JComponent._paintImmediately(Unknown Source)
at javax.swing.JComponent.paintImmediately(Unknown Source)
at javax.swing.RepaintManager.paintDirtyRegions(Unknown Source)
at javax.swing.SystemEventQueueUtilities$ComponentWorkRequest.run(Unknown Source)
at java.awt.event.InvocationEvent.dispatch(Unknown Source)
at java.awt.EventQueue.dispatchEvent(Unknown Source)
at java.awt.EventDispatchThread.pumpOneEventForHierarchy(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.run(Unknown Source)

io nn so proprio ke fare...
Molz è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2004, 13:02   #5
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
non riesci a farne il catch allora perchè e' in un thread diverso.

perche' chiami updateUI? e' proprio necessario?
generalmente il chiamarlo espressamente incica qualche problema col model sottostante.
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2004, 13:10   #6
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
Se nn kiamo updateUI nn visualizzo i cambiamenti del JTree.

Le varie repaint update di Graphic nn danno nessun effetto

Cmq il Thread diverso dove nasce l'eccezione, da qello ke ho capito, lo fa Java con le sue API
Molz è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2004, 14:48   #7
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
Prova così:

Codice:

      while(true){
        Thread.sleep(1000 * 10);
        /*codice vario*/
        try{
          ilFrameDaAggiornare.jTree.updateUI();
        }catch(Exception e){/* qui non entra */}
     }
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 12:42   #8
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
Ok proverò, domani t saprò dire (prima nn posso), cmq anke la sleep va in 1 blocco try-catch.

Xkè dovrebbe cambiare qalcosa?
Molz è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 14:16   #9
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
Bhè innanzitutto è più corretto... quel while (true) indica che vuoi ripetere all'"infinito" il codice, il fallimento di una sleep o di un'updateUI non deve pregiuducare le successive esecuzioni... E poi... bhè, quando incontro un problema assurdo, rispondo con una soluzione ancora più assurda, magari mi va bene
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 12:21   #10
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
La soluzione nn era abbastanza assurda! Il problema è rimasto. Vabbè visto ke cmq l'esecuzione nn mi da problemi penso ke risolverò il problema così:

java mioPackage.mioMain 2> /dev/null

Okkio nn vede, cuore nn duole
Molz è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 13:10   #11
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Non credo sia la soluzione al problema perchè quanto scrivo evita problemi di dead-lock dovuti all'istruzione di aggiornamento grafico "arrembante". Ma non si sa mai.

Codice:
while(true){
        Thread.sleep(1000 * 10);
        /*codice vario*/
          ilFrameDaAggiornare.jTree.updateUI();
}
Questo pezzo è ad alto rischio. Tutte le istruzioni di aggiornamento grafico di un componente Swing devono essere delegate all'unico thread EventDispatcher.

La delega è realizzata in tutti i gestori di evento AWT: nell'esecuzione comune di un interfaccia grafica pertanto non c'è nulla da aggiungere (premo un bottone, il controllo passa ad un actionListener, nell'actionListener aggiorno un componente e tutto fila liscio, perchè ActionListener è "swing-safe". Vale per tutti i listener AWT).

Quando Thread diversi da EventDispatcher contribuiscono all'aggiornamento di un componente Swing entrano in gioco i metodi SwingUtilities.invokeLater(Runnable) e SwingUtilities.invokeAndWait(Runnable).

Quello che i metodi citati fanno è accodare le istruzioni contenute nel metodo "run()" del Runnable in argomento all'EventDispatcher.

Il primo accoda l'evento e restituisce immediatamente il controllo al chiamante, il secondo attende che l'esecuzione del "run()" sia completata (ecco perchè questo non può essere chiamato all'interno dell'EventDispatcher: attenderebbe sè stesso).

Forma corretta:

Codice:
while(true){
        Thread.sleep(1000 * 10);
        /*codice vario*/
        Runnable updater = new Runnable() {
              public void run() {
                    ilFrameDaAggiornare.jTree.updateUI();
              }
        }
        SwingUtilities.invokeLater(updater);
}
ilFrameDaAggiornare deve diventare "final". Normalmente è fattibile senza modifiche al codice salvo l'aggiunta di un "final" alla dichiarazione.

Ciao.

[update]
ho corretto qualche strafalcione di grammatica

Ultima modifica di PGI : 01-06-2004 alle 13:41.
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 13:21   #12
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
Grazie mille.
Nn so se funzionerà, ma almeno adesso ne so d + su qello ke sto facendo.

Domani t saprò dire. Ciao
Molz è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 15:50   #13
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
PGI, come al solito, ha ragione... Dai un'occhiata anche alla classe SwingWorker.

Per levarti la soddisfazione di capire il tipo di errore, catcha, invece che Exception, Throwable che è il papà di tutti gli errori. Anche la classe Throwable ha il metodo printSTackTrace()...
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2004, 09:49   #14
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
E quindi?
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2004, 14:39   #15
Molz
Member
 
Iscritto dal: May 2003
Messaggi: 119
La soluzione d PGI funziona.

Invece catchando Throwable nn cambia niente, infatti l'errore era 1 NullPointerException e veniva generata in 1 altro Thread e qindi nn riuscivo a gestirla lì.

Grazie mille a tutti
Molz è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
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: 21:58.


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