В эликсире есть Карты:
> map = %{:a => "one", :b => "two"} # = %{a: "one", b: "two"}
> map.a # = "one"
> map[:a] # = "one"
У нас также есть списки ключевых слов:
> kl = [a: "one", b: "two"] # = [a: "one", b: "two"]
> kl2 = [{:a, "one"},{:b, "two"}] # = [a: "one", b: "two"]
> kl == kl2 # = true
> kl[:a] # = "one"
> kl.a # = ** (ArgumentError)
Почему оба?
Синтаксис? Это потому, что списки ключевых слов имеют более гибкий синтаксис, позволяющий определять их без фигурных скобок и даже без скобок в качестве последнего параметра вызова функции? Тогда почему бы не дать Maps этот синтаксический сахар?
Повторяющиеся ключи? Это потому, что списки ключевых слов могут иметь повторяющиеся ключи? Зачем вам нужен и доступ к стилю карты, и дублирующиеся ключи?
Производительность? Это потому, что списки ключевых слов более эффективны? Тогда зачем нужны Карты? И не должны ли карты быть более производительными при поиске членов по ключу, чем список кортежей?
JS Array и Ruby Hash похожи на внешний вид? Это оно?
Я понимаю, что структурно это разные представления данных. Мне кажется, что списки ключевых слов в elixir служат для усложнения языка за счет исключительного синтаксиса (3 различных синтаксических варианта), совпадения вариантов использования с картами и неясного преимущества.
В чем преимущество использования списков ключевых слов?