SORU
10 Temmuz 2009, Cuma


Bir HashSet süre gelen Öğeleri Yineleme

Eğer bir Java öğeleri kaldırmak için çalışırsanızHashSetyineleme olsa da, bir benConcurrentModificationException. Ne öğeleri kümesini kaldırmak için en iyi yoldurHashSetaşağıdaki örnekte olduğu gibi?

Set<Integer> set = new HashSet<Integer>();

for(int i = 0; i < 10; i  )
    set.add(i);

// Throws ConcurrentModificationException
for(Integer element : set)
    if(element % 2 == 0)
    	set.remove(element);

Burada bir çözümdür, ama çok zarif sanmıyorum:

Set<Integer> set = new HashSet<Integer>();
Collection<Integer> removeCandidates = new LinkedList<Integer>();

for(int i = 0; i < 10; i  )
    set.add(i);

for(Integer element : set)
    if(element % 2 == 0)
    	removeCandidates.add(element);

set.removeAll(removeCandidates);

Teşekkürler!

CEVAP
10 Temmuz 2009, Cuma


El ile ayarlama öğeleri üzerinde yineleme yapabilirsiniz:

Iterator<Integer> iterator = set.iterator();
while (iterator.hasNext()) {
    Integer element = iterator.next();
    if (element % 2 == 0) {
        iterator.remove();
    }
}

Genellikle bu desen while bir döngü yerine: for bir döngü kullanarak göreceksiniz

for (Iterator<Integer> i = set.iterator(); i.hasNext();) {
    Integer element = i.next();
    if (element % 2 == 0) {
        i.remove();
    }
}

İnsanlar belirttiği gibi, for bir döngü kullanarak yineleyici değişken (bu durumdai) daha küçük bir kapsam ile sınırlı tutar için tercih edilir.

Bunu Paylaş:
  • Google+
  • E-Posta
Etiketler:

YORUMLAR

SPONSOR VİDEO

Rastgele Yazarlar

  • apenney888

    apenney888

    27 EKİM 2010
  • Myron and Nejusha dance

    Myron and Ne

    2 AĞUSTOS 2012
  • WePlayWeWatch

    WePlayWeWatc

    3 Temmuz 2013