39 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | ||
| title: Pattern Matching
 | ||
| localeTitle: 模式匹配
 | ||
| ---
 | ||
| ## 模式匹配
 | ||
| 
 | ||
| 模式匹配是Elixir从Erlang继承的技术。这是一种非常强大的技术,它允许我们从复杂的数据结构中提取更简单的子结构,如列表,元组,映射等。
 | ||
| 
 | ||
| 比赛有2个主要部分,左侧和右侧。右侧是任何类型的数据结构。左侧尝试匹配右侧的数据结构,并将左侧的任何变量绑定到右侧的相应子结构。如果未找到匹配项,则操作员会引发错误。
 | ||
| 
 | ||
| 最简单的匹配是左侧的单个变量和右侧的任何数据结构。这个变量将匹配任何东西。例如:  
 | ||
| `x = 12`  
 | ||
| `x = "Hello"`  
 | ||
| `IO.puts(x)`
 | ||
| 
 | ||
| 您可以将变量放在结构中,以便捕获子结构。例如:  
 | ||
| `[var_1, _unused_var, var_2] = [{"First variable"}, 25, "Second variable" ]`  
 | ||
| `IO.puts(var_1)`  
 | ||
| `IO.puts(var_2)`
 | ||
| 
 | ||
| 这将在var _1中_存储值`{"First variable"}`在var _2中存储`"Second variable"`_ 。还有一个特殊的\_变量(或带有'\_'前缀的变量),它与其他变量完全一样但是告诉elixir, “确保有些东西在这里,但我并不在乎它到底是什么。”在前面的例子中,\_unused\_var就是这样一个变量。
 | ||
| 
 | ||
| 我们可以使用这种技术匹配更复杂的模式。例如,如果要打开并在列表中的元组中获取数字,该列表本身位于列表中,则可以使用以下命令:  
 | ||
| `[_, [_, {a}]] = ["Random string", [:an_atom, {24}]]`  
 | ||
| `IO.puts(a)`
 | ||
| 
 | ||
| 上述程序产生以下结果 -  
 | ||
| `24`
 | ||
| 
 | ||
| 这将绑定到24.其他值被忽略,因为我们使用'\_'。
 | ||
| 
 | ||
| 在模式匹配中,如果我们在右侧使用变量,则使用其值。如果要使用左侧变量的值,则需要使用pin运算符。
 | ||
| 
 | ||
| 例如,如果您的变量“a”的值为25,并且您希望将其与另一个值为25的变量“b”匹配,那么您需要输入 -  
 | ||
| `a = 25`  
 | ||
| `b = 25`  
 | ||
| `^a = b`
 | ||
| 
 | ||
| 最后一行匹配a的当前值,而不是将其赋值给b的值。如果我们有一组不匹配的左侧和右侧,匹配运算符会引发错误。例如,如果我们尝试将元组与列表或大小为2的列表与大小为3的列表进行匹配,则会显示错误。 |