Эликсир - Потоки

Многие функции ожидают перечислимого и возвращают listназад. Это означает, что при выполнении нескольких операций с Enum каждая операция будет генерировать промежуточный список, пока мы не достигнем результата.

Потоки поддерживают ленивые операции в отличие от активных операций перечислениями. Коротко,streams are lazy, composable enumerables. Это означает, что потоки не выполняют операции, если в этом нет крайней необходимости. Давайте рассмотрим пример, чтобы понять это -

odd? = &(rem(&1, 2) != 0)
res = 1..100_000 |> Stream.map(&(&1 * 3)) |> Stream.filter(odd?) |> Enum.sum
IO.puts(res)

Когда вышеуказанная программа запускается, она дает следующий результат -

7500000000

В приведенном выше примере 1..100_000 |> Stream.map(&(&1 * 3))возвращает тип данных, фактический поток, который представляет вычисление карты в диапазоне 1..100_000. Это представление еще не оценивалось. Вместо создания промежуточных списков потоки создают серию вычислений, которые вызываются только тогда, когда мы передаем базовый поток модулю Enum. Потоки полезны при работе с большими, возможно, бесконечными коллекциями.

У потоков и перечислений много общих функций. Потоки в основном предоставляют те же функции, что и в модуле Enum, который генерирует списки в качестве возвращаемых значений после выполнения вычислений над входными перечислимыми. Некоторые из них перечислены в следующей таблице -

Sr. No. Функция и ее описание
1

chunk(enum, n, step, leftover \\ nil)

Выполняет потоковую передачу перечислимого в блоки, содержащие по n элементов каждый, причем каждый новый блок запускает элементы шага в перечислимый.

2

concat(enumerables)

Создает поток, который перечисляет каждое перечислимое в перечисляемом.

3

each(enum, fun)

Выполняет заданную функцию для каждого элемента.

4

filter(enum, fun)

Создает поток, который фильтрует элементы в соответствии с заданной функцией при перечислении.

5

map(enum, fun)

Создает поток, который будет применять данную функцию при перечислении.

6

drop(enum, n)

Лениво отбрасывает следующие n элементов из перечисляемого.