Эликсир - Постижения
Понимание списков - это синтаксический сахар для перебора перечислимых элементов в Elixir. В этой главе мы будем использовать пояснения для итерации и генерации.
Основы
Когда мы посмотрели на модуль Enum в главе о перечислениях, мы натолкнулись на функцию карты.
Enum.map(1..3, &(&1 * 2))
В этом примере мы передадим функцию в качестве второго аргумента. Каждый элемент в диапазоне будет передан в функцию, а затем будет возвращен новый список, содержащий новые значения.
Отображение, фильтрация и преобразование - очень распространенные действия в Elixir, поэтому есть несколько другой способ достижения того же результата, что и в предыдущем примере -
for n <- 1..3, do: n * 2
Когда мы запускаем приведенный выше код, он дает следующий результат:
[2, 4, 6]
Второй пример - понимание, и, как вы, вероятно, видите, это просто синтаксический сахар для того, чего вы также можете достичь, если используете Enum.mapфункция. Однако с точки зрения производительности нет реальных преимуществ использования понимания перед функцией из модуля Enum.
Понимания не ограничиваются списками, но могут использоваться со всеми перечисляемыми.
Фильтр
Вы можете рассматривать фильтры как своего рода охрану для понимания. Когда возвращается отфильтрованное значениеfalse или же nilон исключен из окончательного списка. Давайте переберем диапазон и будем беспокоиться только о четных числах. Мы будем использоватьis_even функция из модуля Integer, чтобы проверить, четное значение или нет.
import Integer
IO.puts(for x <- 1..10, is_even(x), do: x)
Когда приведенный выше код запускается, он дает следующий результат:
[2, 4, 6, 8, 10]
Мы также можем использовать несколько фильтров в одном понимании. Добавьте другой фильтр, который вы хотите, послеis_even фильтр через запятую.
: в вариант
В приведенных выше примерах все понимания возвращали списки в качестве своего результата. Однако результат понимания может быть вставлен в различные структуры данных путем передачи:into вариант к пониманию.
Например, bitstring генератор можно использовать с параметром: into, чтобы легко удалить все пробелы в строке -
IO.puts(for <<c <- " hello world ">>, c != ?\s, into: "", do: <<c>>)
Когда приведенный выше код запускается, он дает следующий результат:
helloworld
Приведенный выше код удаляет все пробелы из строки, используя c != ?\s filter, а затем с помощью параметра: into помещает все возвращенные символы в строку.