Статья подготовлена для студентов курса «Разработчик C#» в образовательном проекте OTUS. Начинающие программисты при работе с коллекциями часто не придают значения оптимизации производительности (например, при работе с БД). Допустим, программист хочет реализовать функцию, возвращающую список сотрудников с оформленными ими заказами. В дальнейшем эту функцию будут использовать для отображения на внутреннем портале организации. Он делает это так: Сначала он получает из БД список сотрудников (в котором может быть 300-500 человек), и по каждому сотруднику подтягивается информация об обработанных им заказах, число которых может достигать нескольких сотен или даже тысяч. Команда, работающая над порталом организации, оформила список сотрудников с постраничной навигацией. Но время получения информации при этом не уменьшилось, поскольку информация по всем сотрудникам и всем заказам запрашивается каждый раз, даже если пользователь портала открывает только первую страницу со списком сотрудник