Elm - 元组
有时,可能需要存储不同类型的值的集合。Elm 为我们提供了一种称为元组的数据结构来满足此目的。
元组表示异构值的集合。换句话说,元组能够存储不同类型的多个字段。元组存储固定数量的值。当您想要从函数返回多个不同类型的值时,元组非常有用。这些数据结构与 elm 中的其他类型一样是不可变的。
句法
(data1,data2)
一个简单的例子如下所示 -
> ("TuotrialsPoint",5,True,"Hyderabad") ("TuotrialsPoint",5,True,"Hyderabad") : ( String, number, Bool, String )
在后续部分中,我们将了解不同的元组操作。
第一的
此操作从元组中提取第一个值。
句法
Tuple.first tuple_name > Tuple.first <function> : ( a1, a2 ) -> a1
插图
> Tuple.first (10,"hello") 10 : number
第二
第二个元组操作从元组中提取第二个值。
句法
Tuple.second tuple_name > Tuple.second <function> : ( a1, a2 ) -> a2
插图
> Tuple.second (10,"hello") "hello" : String
元组列表
列表可以存储元组。如果在列表中使用元组,请确保它们都具有相同的数据类型并且具有相同数量的参数。
插图
> [("hello",20),("world",30)] [("hello",20),("world",30)] : List ( String, number )
带函数的元组
函数可以返回元组。此外,元组可以作为参数传递给函数。
图1
以下示例定义了函数 fn_checkEven。该函数接受一个整数值作为参数并返回一个元组。
> fn_checkEven no = \ if no%2 == 0 then \ (True,"The no is Even")\ else \ (False,"No is not even") <function> : Int -> ( Bool, String ) > fn_checkEven 10 (True,"The no is Even") : ( Bool, String ) > fn_checkEven 11 (False,"No is not even") : ( Bool, String ) >
图2
下面将一个元组作为参数传递给函数。
> fn_add (a,b) = \ | a+b <function> : ( number, number ) -> number > fn_add (10,20) 30 : number
函数fn_add接受一个包含 2 个数值的元组并返回它们的总和。
解构
解构涉及将元组分解为单独的值。要访问具有三个或更多元素的元组中的各个值,我们使用解构。在这里,我们将元组中的每个值分配给不同的变量。使用 _ 可以为将被忽略或跳过的值定义占位符。
插图
> (first,_,_) = (10,20,30) 10 : number > first 10 : number
插图
在此示例中,我们将使用 let..in 块语法来解构。let 块包含变量,in 块包含应计算的表达式和应返回的值。
> t1 = (10,20,30) (10,20,30) : ( number, number1, number2 ) > let \ (a,b,c) = t1 \ in\ a + b +c 60 : number
我们在 let 子句中声明变量 abc 并使用 in 子句访问它们。