0 added
0 removed
Original
2026-01-01
Modified
2026-02-26
1
<p>Большинство операций над списками строятся вокруг их обхода с перебором всех элементов. Например, если у нас есть список температур в городе за неделю, то для подсчета средней температуры нам понадобится все сложить и поделить на количество элементов. Обход списка можно выполнить несколькими способами:</p>
1
<p>Большинство операций над списками строятся вокруг их обхода с перебором всех элементов. Например, если у нас есть список температур в городе за неделю, то для подсчета средней температуры нам понадобится все сложить и поделить на количество элементов. Обход списка можно выполнить несколькими способами:</p>
2
<ul><li>С помощью цикла<em>for</em></li>
2
<ul><li>С помощью цикла<em>for</em></li>
3
<li>С помощью цикла<em>for-each</em></li>
3
<li>С помощью цикла<em>for-each</em></li>
4
<li>С помощью метода forEach(). Понимание этого способа требует знакомства с lambda-функциями, которые будут изучаться позже</li>
4
<li>С помощью метода forEach(). Понимание этого способа требует знакомства с lambda-функциями, которые будут изучаться позже</li>
5
</ul><h2>Обход с помощью цикла for</h2>
5
</ul><h2>Обход с помощью цикла for</h2>
6
<p>В этом случае движение по списку идет за счет счетчика цикла, который одновременно является индексом в списке.</p>
6
<p>В этом случае движение по списку идет за счет счетчика цикла, который одновременно является индексом в списке.</p>
7
<p>Такой вид обхода полезен тогда, когда во время каждой итерации нам нужно обращаться не только к текущему элементу списка, но и, например, соседним. В остальных ситуациях проще использовать цикл<em>for-each</em></p>
7
<p>Такой вид обхода полезен тогда, когда во время каждой итерации нам нужно обращаться не только к текущему элементу списка, но и, например, соседним. В остальных ситуациях проще использовать цикл<em>for-each</em></p>
8
<h2>Обход с помощью цикла for-each</h2>
8
<h2>Обход с помощью цикла for-each</h2>
9
<p><em>for-each</em>прячет от нас процесс перебора, так, что на каждой итерации мы работаем только с текущим элементом</p>
9
<p><em>for-each</em>прячет от нас процесс перебора, так, что на каждой итерации мы работаем только с текущим элементом</p>
10
<p>Технически<em>for-each</em>работает не со списками, а с объектами, реализующими интерфейс Iterable. Этот интерфейс добавлен в List и реализован в ArrayList, поэтому все происходит автоматически.</p>
10
<p>Технически<em>for-each</em>работает не со списками, а с объектами, реализующими интерфейс Iterable. Этот интерфейс добавлен в List и реализован в ArrayList, поэтому все происходит автоматически.</p>
11
<p>Итератор понятие кроссязыковое, оно встречается в практически всех языках программирования. По сути это объект, который позволяет обходить коллекцию элементов. Ниже пример кода, который вызывается на самом деле при использовании цикла<em>for-each</em>:</p>
11
<p>Итератор понятие кроссязыковое, оно встречается в практически всех языках программирования. По сути это объект, который позволяет обходить коллекцию элементов. Ниже пример кода, который вызывается на самом деле при использовании цикла<em>for-each</em>:</p>
12
<p>Зачем нужен отдельный объект для обхода коллекции? Дело в том, что во время обхода нужно помнить позицию текущего элемента. В случае обычного цикла мы управляем этим сами через счетчик цикла. Итератор же позволяет скрыть эту логику внутри, за счет сохранения текущей позиции. В итоге благодаря этому логика обхода коллекции элементов находится внутри самой коллекции. В свою очередь это дает возможность реализовать универсальный цикл<em>for-each</em>. Использовать итератор напрямую, при этом, не нужно.</p>
12
<p>Зачем нужен отдельный объект для обхода коллекции? Дело в том, что во время обхода нужно помнить позицию текущего элемента. В случае обычного цикла мы управляем этим сами через счетчик цикла. Итератор же позволяет скрыть эту логику внутри, за счет сохранения текущей позиции. В итоге благодаря этому логика обхода коллекции элементов находится внутри самой коллекции. В свою очередь это дает возможность реализовать универсальный цикл<em>for-each</em>. Использовать итератор напрямую, при этом, не нужно.</p>
13
<h2>Изменение списка во время обхода</h2>
13
<h2>Изменение списка во время обхода</h2>
14
<p>В общем, изменение списка во время его обхода не рекомендуется из-за потенциальных ошибок и непредсказуемого поведения. Представьте что мы добавляем элемент в список во время перебора. Как должен вести себя цикл? Он должен добавить одну итерацию в процессе? По этой причине, рекомендуется создавать новый список и работать в цикле уже с ним. Ниже пример с удалением всех температур ниже 20 градусов:</p>
14
<p>В общем, изменение списка во время его обхода не рекомендуется из-за потенциальных ошибок и непредсказуемого поведения. Представьте что мы добавляем элемент в список во время перебора. Как должен вести себя цикл? Он должен добавить одну итерацию в процессе? По этой причине, рекомендуется создавать новый список и работать в цикле уже с ним. Ниже пример с удалением всех температур ниже 20 градусов:</p>
15
15