Так как Elixir имеет доступ к виртуальной машине Эрланг (Erlang VM), то это позволяет использовать все библиотеки, включая стандартную библиотеку Erlang, в коде на Elixir.
Модули Erlang представлены атомами в нижнем регистре, такими как :os
и :timer
. Атомы - специальные строки, которые начинаются с символа :
. Тему атомов подробнее рассмотрим в следующем модуле, а пока вернемся к примерам вызова Erlang кода из Elixir:
# функция которая переводит секунды в миллисекунды
:timer.seconds(5)
# => 5000
:os.cmd(~c"whoami")
# => ~c"root\n"
:os.getenv(~c"SHELL")
# => ~c"/bin/zsh"
Для подключения пакетов Erlang достаточно указать их в mix.exs:
# в mix.exs
def deps do
[{:png, github: "yuce/png"}]
end
# теперь мы можем пользоваться этой библиотекой
png =
:png.create(%{:size => {30, 30}, :mode => {:indexed, 8}, :file => file, :palette => palette})
Однако есть и некоторые различия, например в атомах:
# в эликсире
:my_atom
# в эрланге
my_atom.
Когда мы говорим о строках в Elixir, имеются ввиду бинарные объекты в UTF-8. В Erlang строки тоже используют двойные кавычки, но являются списком символов:
# в эликсире
is_list('Example') # => true
is_list("Example") # => false
is_binary("Example") # => true
<<"Example">> === "Example" # => true
# в эрланге
is_list('Example'). # => false
is_list("Example"). # => true
is_binary("Example"). # => false
is_binary(<<"Example">>). # => true
Многие старые библиотеки Erlang могут не поддерживать бинарные строки, потому нужно превращать строки Elixir в строковые списки. Это достигается функцией to_charlist
или с помощью сигиля ~c
. Сигили - особенные метки, которые выполняют преобразования над строками, подробнее их рассмотрим в следующем упражнении, а пока вернемся к примерам:
# функция подсчитывающее количество слов из erlang
:string.words("Hello World")
# => ** (FunctionClauseError) no function clause matching in :string.strip_left/2
# =>
# => The following arguments were given to :string.strip_left/2:
# =>
# => # 1
# => "Hello World"
# =>
# => # 2
# => 32
# =>
# => (stdlib) string.erl:1661: :string.strip_left/2
# => (stdlib) string.erl:1659: :string.strip/3
# => (stdlib) string.erl:1597: :string.words/2
words = to_charlist("Hello World")
:string.words(words) # => 2
# или с помощью сигиля
:string.words(~c"Hello World") # => 2
В Erlang переменные начинаются с заглавной буквы, и повторная привязка (присваивание) не допускается:
# в эликсире
x = 10
x = 20
x1 = x + 10 # => 30
# в эрланге
X = 10.
X = 20.
# ** exception error: no match of right hand side value 20
X1 = X + 10. # => 20
Создайте функцию hours_to_milliseconds
которая конвертирует часы в миллисекунды, обратите внимание на :timer
библиотеку из Erlang:
Solution.hours_to_milliseconds(0)
# => 0
Solution.hours_to_milliseconds(1.5)
# => 5400000.0
Solution.hours_to_milliseconds(2)
# => 7200000
Команда проекта находится в телеграм-сообществе по ссылке https://ttttt.me/HexletLearningBot. Там можно задать любой вопрос и повлиять на проект
Если вы зашли в тупик, то самое время поговорить с нашим асситентом Тота во вкладке "Обсуждение". Как правильно задать вопрос:
Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.
Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи. В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.
Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в обратной связи нашего сообщества
Привет! Я Тота и моя задача помочь в обучении. Чтобы активировать меня, нужно зарегистрироваться или залогиниться, если у вас уже есть аккаунт
Ваше упражнение проверяется по этим тестам
1defmodule Test do
2 use ExUnit.Case
3
4 test "hours_to_milliseconds work" do
5 assert Solution.hours_to_milliseconds(0) == 0
6 assert Solution.hours_to_milliseconds(1) == 3_600_000
7 assert Solution.hours_to_milliseconds(1.5) == 5_400_000.0
8 assert Solution.hours_to_milliseconds(2) == 7_200_000
9 end
10end
11
Решение учителя откроется через: