Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS e HIFIMAN uniscono le forze per creare ROG Kithara, cuffie gaming con driver magnetici planari da 100mm, design open-back e microfono MEMS full-band. Una proposta che ambisce a coniugare fedeltà per audiofili e performance ludiche, disponibili a 319 euro
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
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


ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
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...
Leica Leitzphone: la collaborazione con ...
Il telescopio spaziale Hubble, Euclid e ...
Il telescopio spaziale James Webb ha oss...
Mike Fincke era l'astronauta di Crew-11 ...
WhatsApp colma una sua lacuna: stanno pe...
Panasonic LUMIX DMW-DMS1: il nuovo micro...
Samsung preferisce vendere ad altri le s...
OpenAI vince contro xAI (per ora): l'azi...
Electronic Arts domina la classifica dei...
Micron annuncia le GDDR7 da 3 GB fino a ...
Tempi di intrusione ulteriormente ridott...
Smartwatch: il mercato cresce, Apple si ...
Stellaris sarà la prima centrale ...
HUAWEI Band 11 e 11 Pro ufficiali: le no...
Assetto Corsa Rally si aggiorna con Mont...
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: 23:13.


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