官术网_书友最值得收藏!

Tuples

Tuples are used to group a fixed number of elements together. They can hold any value—even other tuples. They are stored contiguously in memory, which provides constant access time to elements inside a tuple. You create a tuple surrounding the elements with curly brackes ({ and }), and separate the elements with commas:

iex> {:ok, 3.14}
{:ok, 3.14}

A common usage of tuples in Elixir is to pattern-match on the result of a function to ensure its success (usually with an :ok atom) or deal with an error. We will be looking to pattern matching and functions later in this chapter.

To access an element inside a tuple, we use the elem function (from the Kernel module), providing the tuple and a zero-based index:

iex> result = {:ok, 3.14}
{:ok, 3.14}
iex> elem(result, 1)
3.14
Functions from the Kernel module are auto-imported. Thus, we don't need to prefix them with the module name.

To change the elements on a tuple, you can use the put_elem function. The arguments are similar to the elem function, but you also provide the new value for that position of the tuple:

iex> put_elem(result, 1, 1.61)
{:ok, 1.61}
iex> result
{:ok, 3.14}

Notice how the result variable hasn't changed. As we discussed in the beginning of this chapter, data in Elixir is immutable. As such, although we've updated the tuple with a new value, the original tuple hasn't changed—Elixir updated the value on a copy of the original tuple. This way our code is side-effect free, and any other function holding a reference to the result variable won't have any surprises.

The general recommendation in Elixir is that tuples should hold up to four elements—anything more than that and you probably should be using another type.

主站蜘蛛池模板: 鞍山市| 抚州市| 汉寿县| 苏尼特左旗| 龙岩市| 六安市| 闵行区| 西乌珠穆沁旗| 安陆市| 南康市| 崇明县| 阿克陶县| 水富县| 临邑县| 义乌市| 同仁县| 岳西县| 长沙市| 兴国县| 花垣县| 兴隆县| 武乡县| 乐平市| 平凉市| 平昌县| 明水县| 岑溪市| 恩平市| 菏泽市| 英超| 广西| 昌黎县| 永修县| 南充市| 嫩江县| 南漳县| 兴宁市| 宁陵县| 新津县| 梁河县| 三明市|