Прямо сейчас у меня есть программа, содержащая фрагмент кода, который выглядит так:
while (arrayList.iterator().hasNext()) {
//value is equal to a String value
if( arrayList.iterator().next().equals(value)) {
// do something
}
}
Правильно ли я делаю это в части перебора ArrayList?
Я получаю следующую ошибку:
java.lang.ArrayIndexOutOfBoundsException: -1
at java.util.ArrayList.get(Unknown Source)
at main1.endElement(main1.java:244)
at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.endElement(Unknown Source)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanEndElement(Unknown Source)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(Unknown Source)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(Unknown Source)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source)
at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(Unknown Source)
at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(Unknown Source)
at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(Unknown Source)
at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(Unknown Source)
at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source)
at javax.xml.parsers.SAXParser.parse(Unknown Source)
at javax.xml.parsers.SAXParser.parse(Unknown Source)
at main1.traverse(main1.java:73)
at main1.traverse(main1.java:102)
at main1.traverse(main1.java:102)
at main1.main(main1.java:404)
Я бы показал остальную часть кода, но она довольно обширна, и если я не выполняю итерацию правильно, я предполагаю, что единственная возможность заключается в том, что я не инициализирую ArrayList
должным образом.
java
arraylist
iterator
indexoutofboundsexception
Этот 0ne программист
источник
источник
forEach
метод: stackoverflow.com/questions/16635398/…Ответы:
Нет: вызывая
iterator
дважды на каждой итерации, вы все время получаете новые итераторы.Самый простой способ написать этот цикл - использовать конструкцию for-each :
Что касается
Вы просто пытались получить номер элемента
-1
из массива. Подсчет начинается с нуля.источник
do array.each |s| unless (s.nil?) end end
Have you heard of
кажется оскорбительным (без причины), но я не родной. В остальном отлично.Хотя я согласен с тем, что принятый ответ обычно является лучшим решением и, безусловно, более простым в использовании, я заметил, что никто не показал правильное использование итератора. Вот краткий пример:
источник
или
Но будьте осторожны, ArrayList может содержать нулевые значения . Так что сравнение должно быть
когда вы уверены, что значение не равно нулю, или вы должны проверить, является ли данный элемент нулевым.
источник
Вы также можете использовать это так:
Хорошая практика - приводить и использовать объект. Например, если «arrayList» содержит список объектов «Object1». Затем мы можем переписать код как:
источник
Вы также можете выполнить цикл for, как и для массива, но вместо array [i] вы должны использовать list.get (i)
источник
Помимо ответа larsmans (который действительно прав), исключение в вызове метода get (), поэтому опубликованный вами код не является тем, который вызывает ошибку.
источник
Эффективный способ итерации ваш
ArrayList
последующее этой ссылкой . Этот тип улучшит производительность цикла во время итерации.источник
итерация с использованием итератора не является отказоустойчивой, например, если вы добавляете элемент в коллекцию после создания итератора, тогда он вызовет исключение concurrentmodificaionexception. Кроме того, он не является потокобезопасным, вы должны сделать его потокобезопасным извне.
Так что лучше использовать структуру for-each цикла for. Это по крайней мере безотказно.
источник