我试图了解对构造和表示。让我们看一下以下结果:
(length (cons '(a b) '(d e f)))
=> 4
现在让我们切换顺序:
(length (cons '(d e f) '(a b)))
=> 3
但
(length (car (cons '(d e f) '(a b))))
=> 3
你能解释一下上面的结果吗?汽车和cdr有什么区别?
请记住,这cons
只是将两件事粘在一起,由于历史原因,第一个被称为 ,car
第二个被称为cdr
.
如果第二个恰好是一个正确的列表,那么结果也是一个列表。因此,列表被定义为cons
ing 一个元素的结果与 ing 一个元素的结果cons
......等等,直到我们到达空列表'()
。例如:
(cons 1 (cons 2 (cons 3 '())))
=> '(1 2 3)
在处理列表时,car
将列表的第一个元素和cdr
其余元素视为列表,并cons
在列表的开头添加一个元素 - 该元素可以是任何东西,包括另一个列表。它只是被添加到头部,列表没有“合并”(我们使用append
它)。看一看:
(car '(1 2 3))
=> 1
(cdr '(1 2 3))
=> '(2 3)
现在,关于您的示例 - 第一个添加'(a b)
为列表的第一个元素,其余部分是'(d e f)
,所以我们现在有一个 4 元素列表,如下所示:
(cons '(a b) '(d e f))
=> '((a b) d e f)
与第二个示例类似:我们将第一个元素添加'(d e f)
到其余元素'(a b)
中,我们得到一个 3 元素列表:
(cons '(d e f) '(a b))
=> '((d e f) a b)
最后,如果我们调用car
上面的列表,我们会得到它的第一个元素——恰好是'(d e f)
,很明显它有 3 个元素:
(car (cons '(d e f) '(a b)))
=> '(d e f)