Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-07-2010, 12:56   #1
Lim
Senior Member
 
L'Avatar di Lim
 
Iscritto dal: Dec 2000
Messaggi: 501
[Java] Rimozione iterativa da una lista

Salve a tutti.
Sono appena incappato in un problema nella gestione delle liste.

Ho un insieme di oggetti che popolano una lista.
Ad intervalli di tempo prestabiliti, vorrei controllare OGNI elemento della lista per verificare una condizione su un attributo di ogni oggetto. Se la condizione è vera (o falsa) l'oggetto in questione deve essere rimosso dalla lista.
Ho tentato due approcci, per semplicità incollo il codice qui sotto:

Codice:
public List<MyObj> lista=new ArrayList<MyObj>();
...
...
int size=lista.size();
for(int i=0;i<size;i++){
	if(!(lista.get(i).isAlive())) {
                lista.remove(i);
        }			
}
Questa prima implementazione restituisce (giustamente):
java.lang.IndexOutOfBoundsException, esattamente alla metà delle dimensioni iniziali della lista.

L'altra implementazione, invece:
Codice:
for(MyObj o: lista){
        if(!(o.isAlive())) {
                lista.remove(o);
        }			
}
viene lanciata l'eccezione: java.util.ConcurrentModificationException

Ho provato anche con gli Iterator, ma viene lanciata comunque java.util.ConcurrentModificationException

Sono sicuro che c'è un modo semplice per risolvere questo problema, ma al momento non mi viene proprio in mente.
Qualcuno ha un suggerimento?
Lim è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2010, 13:01   #2
astorcas
Senior Member
 
L'Avatar di astorcas
 
Iscritto dal: Jan 2005
Città: Siena
Messaggi: 1313
Codice:
List<myObj> objectToRemove=new ArrayList<myObj>();
for(MyObj o: lista){
        if(!(o.isAlive())) {
                objectToRemove.add(o);
        }			
}
for(MyObj o: objectToRemove){
       lista.remove(o);
}
oppure iteri su una copia della lista, che credo sia più dispendioso. Non so se ci sono soluzioni migliori.
Ciao
astorcas è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2010, 13:02   #3
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da Lim Guarda i messaggi
Sono sicuro che c'è un modo semplice per risolvere questo problema, ma al momento non mi viene proprio in mente.
Qualcuno ha un suggerimento?
Con l'Iterator della lista, invocando il metodo 'remove' dell'Iterator, non quello della lista (altrimenti parte la ConcurrentModificationException).

Cioè così:
Codice:
Iterator<MyObject> it = lista.iterator();
while (it.hasNext()) {
    MyObject o = it.next();
    if  (! o.isAlive())  
        it.remove();
}
E con un piccolo refactoring volendo puoi arrivare a scrivere:
Codice:
Iterator<MyObject> it = lista.iterator();
while (it.hasNext())
    if (it.next().isNotAlive())  
        it.remove();
@EDIT:
Quote:
Effettivamente volevo evitare di creare una lista di appoggio ogni volta che devo fare il controllo (che avviene ad ogni istante di tempo della mia simulazione), ma se non dovessero esserci altri modi...
Non è affatto neccessario creare una lista di appoggio, nella tua situazione.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 09-07-2010 alle 13:12.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2010, 13:08   #4
Lim
Senior Member
 
L'Avatar di Lim
 
Iscritto dal: Dec 2000
Messaggi: 501
Grazie per le celeri risposte!!

Effettivamente volevo evitare di creare una lista di appoggio ogni volta che devo fare il controllo (che avviene ad ogni istante di tempo della mia simulazione), ma se non dovessero esserci altri modi...

Verifico anche il suggerimento di banryu79, è molto simile al tentativo che avevo fatto con gli iterator, ma non mi ero accorto che potevo dichiararlo così: Iterator<MyObject> ...., forse questa è la soluzione + rapida.
Lim è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2010, 13:13   #5
Lim
Senior Member
 
L'Avatar di Lim
 
Iscritto dal: Dec 2000
Messaggi: 501
Si, perfetto!
Con gli Iterator è rapido ed indolore, funziona alla perfezione!!!

Grazie a tutti!!!
Lim è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2010, 13:16   #6
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da Lim Guarda i messaggi
Si, perfetto!
Con gli Iterator è rapido ed indolore, funziona alla perfezione!!!

Grazie a tutti!!!
Con questo:
Codice:
for(MyObj o: lista){
        if(!(o.isAlive())) {
                lista.remove(o);
        }			
}
lancia l'eccezione perchè questa versione del for "dietro" le quinte usa un Iterator. E quando iteri una collezione tramite un iterator non puoi mutare la collezione se non tramite l'iterator stesso, pena la ConcurrentException.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Missione Artemis II diretta verso la Lun...
Toy Story 5 arriva al cinema: è l...
Intel cambia rotta su Linux? Nuove assun...
Samsung aggiorna Bixby con One UI 8.5: p...
L'Etiopia vieta le auto a combustione: a...
Pirateria audiovisiva: la Guardia di Fin...
Ubisoft conferma due nuovi Far Cry in sv...
Chi vincerà il Festival di Sanrem...
G42 e Cerebras portano in India un super...
Offerte aggiornate del weekend Amazon: 7...
4 MacBook Air in offerta e scende a 939€...
Chrome cambia il tuo modo di lavorare: o...
Minimo storico iPhone 17 su Amazon: 909€...
USA, incriminati tre ingegneri della Sil...
Xbox: Phil Spencer lascia dopo 38 anni, ...
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: 22:20.


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