Clojure - 解构

解构是 Clojure 中的一项功能,它允许人们从数据结构(例如向量)中提取值并将它们绑定到符号,而无需显式遍历数据结构。

让我们看一个例子,了解解构的确切含义以及它是如何发生的。

示例

(ns clojure.examples.example
   (:gen-class))
(defn Example []
   (def my-vector [1 2 3 4])
   (let [[a b c d] my-vector]
   (println a b c d)))
(Example)

上面的程序产生以下输出。

输出

1 2 3 4

在上面的例子中,需要注意以下几点 −

  • 我们将整数向量定义为 1 、2、3 和 4。

  • 然后,我们使用 'let' 语句将 4 个变量(a、b、c 和 d)直接分配给 my-vector 变量。

  • 如果我们对四个变量运行'println'语句,我们可以看到它们已经分别被分配给向量中的值。

因此,clojure 解构了 my-vector 变量,当使用"let"语句对其进行赋值时,该变量有四个值。 然后将解构的四个值相应地分配给四个参数。

如果有多余的变量没有对应的可以赋值的值,那么它们将被赋值为nil。 下面的例子可以清楚地说明这一点。

示例

(ns clojure.examples.hello
   (:gen-class))
(defn Example []
   (def my-vector [1 2 3 4])
   (let [[a b c d e] my-vector]
   (println a b c d e)))
(Example)

上面的程序产生以下输出。 从输出中可以看到,由于最后一个变量"e"在向量中没有对应的值,因此它为零。

输出

1 2 3 4 nil

the-rest

"the-rest"变量用于存储剩余的值,这些值不能分配给任何变量。

以下程序显示了如何使用它的示例。

示例

(ns clojure.examples.example
   (:gen-class))
(defn Example []
   (def my-vector [1 2 3 4])
   (let [[a b & the-rest] my-vector]
   (println a b the-rest)))
(Example)

上面的程序产生以下输出。 从输出中,您可以清楚地看到 3 和 4 的值不能分配给任何变量,因此它们被分配给"the-rest"变量。

输出

1 2 (3 4)

Destructuring Maps

就像向量一样,映射也可以被解构。 以下是如何实现这一点的示例。

示例

(ns clojure.examples.example
   (:gen-class))
(defn Example []
   (def my-map {"a" 1 "b" 2})
   (let [{a "a" b "b"} my-map]
   (println a b)))
(Example)

上面的程序产生以下输出。 从程序中可以清楚地看到"a"和"b"的映射值被分配给a和b的变量。

输出

1 2

与向量的情况类似,如果解构发生时映射中没有对应的值,则该变量将被赋予 nil 值。

Following is an example.

示例

(ns clojure.examples.example
   (:gen-class))
(defn Example []
   (def my-map {"a" 1 "b" 2})
   (let [{a "a" b "b" c "c"} my-map]
   (println a b c)))
(Example)

上面的程序产生以下输出。

输出

1 2 nil