- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在定义无限序列时,我注意到 cons 是避免无限递归所必需的。但是,我不明白的是为什么。这是有问题的代码:
(defn even-numbers
([] (even-numbers 0))
([n] (cons n (lazy-seq (even-numbers (+ 2 n))))))
(take 10 (even-numbers))
;; (0 2 4 6 8 10 12 14 16 18)
(defn even-numbers-v2
([] (even-numbers-v2 0))
([n] (lazy-seq (even-numbers-v2 (+ 2 n)))))
(take 10 (even-numbers-v2))
;; Infinite loooooooooop
最佳答案
Lazy seqs 是一种延迟实际 seq 元素计算的方法,但这些元素最终确实需要计算。这实际上不必涉及 cons
– 例如 clojure.core/concat
在处理分块操作数时使用“分块 conses”,并且可以在 lazy-seq
中包装任何具体的 seq 类型。 – 但是经过很多层lazy-seq
后某种非懒惰的返回如果要进行任何 seq 处理,则是必要的。否则,甚至不会有第一个要到达的元素。
将自己置于一个被传递给惰性序列的函数的位置。调用者已经告诉它,实际上,“这是一个出于所有意图和目的的 seq,但我不想在以后计算实际元素”。现在我们的函数需要一些实际的元素来操作,所以它戳并刺激 seq 试图让它产生一些元素......然后呢?
如果剥落一些 lazy-seq
层最终产生 Cons
单元格、列表、向量上的 seq 或任何其他具有实际元素的具体的类似 seq 的东西,那么棒极了,该函数可以从中读取一个元素并取得进展。
但是如果剥掉这些层的唯一结果是露出更多层,那就是lazy-seq
一直往下,嗯……没有找到元素。并且由于原则上无法确定通过剥离足够多的层是否最终可以生成某些元素(参见 the halting problem ),因此消耗此类无法实现的惰性 seq 的函数通常别无选择,只能继续循环永远。
换个角度,让我们考虑一下您的 even-numbers-v2
功能。它接受一个参数并返回一个 lazy-seq
对象包装对自身的进一步调用。现在,它接收到的原始参数 ( n
) 用于计算递归调用的参数 ( (+ 2 n)
),否则不会放入任何数据结构或以其他方式传送给调用者,因此没有理由为什么它会作为结果序列的一个元素出现。调用者所看到的只是该函数生成了一个惰性 seq 对象,它别无选择,只能解开它以搜索序列的实际元素;当然,然后情况会重演(在这种情况下严格来说不是永远,而是因为 +
在处理 long 时最终会提示算术溢出)。
关于clojure - 为什么需要使用 cons 来防止无限递归,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35952814/
我想在 Lisp 中创建以下列表。 ((lambda(x) (cons x x)) (cons'A 'B)) 创建这个列表,但是 ((lambda(x y) (cons x y)) (cons'A '
(免责声明 - 我知道 Seqs 在 Clojure 中的重要性) 在普通的 lisp 中,cons 函数可用于将两个符号组合成一个列表: (def s 'x) (def l 'y) (cons s
有什么区别: (cons 'a (cons 'b 'c)) ;; (A B . C) 和 (cons 'a '(b.c)) ;; (A B.C) 我需要使用 cons 创建以下列表 ((a.b).c)
我们可以写3 + 4或 (+) 3 4在 F# 中并获得相同的结果,这适用于大多数运算符。 为什么是 cons 运算符 ::表现不同?例如。如果我跑(::) 1 [2;3]我明白了error FS00
$dml = "insert into table ..."; mysql_query($dml,$con); 上面的插入一些东西到一个表中。然后你可以检查它是否成功 if('' == mysql_e
使用 cons 将元素组合到列表和使用 cons 将列表组合到 scheme 中的元素有什么区别? 此外,缺点究竟是如何工作的?它是将元素添加到列表的末尾还是开头? 谢谢! 最佳答案 原始 cons
在命令提示符下,您可以通过执行以下操作来创建内联文本文件: copy con file.txt Hello World ^Z 或者: type con > file.txt Hello World ^
我正在下载一系列 JSON 文件的 url 到列表列表中,稍后进行分析。 baseurl = 10000){ message("Retrieving page ", i)
我想通过打开一个进程并运行 plink 从 c# 打开 SSH 连接。应收集所有输出,并根据结果,程序将触发对 ssh 的操作。我的大问题是,我正在使用几个不同的脚本并且我需要(自动)用户交互。因此我
我得到了许多我解析的平面文件提要。其中一个提要有一个经常包含双引号的评论字段。 这没什么大不了的,除了文件是管道分隔的双引号合格文件之外!! 下面我概述了我得到的字符串。 0|0.9|""|"M"|"
我很困惑 Cons()函数确实如此,在 from 的函数定义中。 最佳答案 什么 Stream代表是lazy和潜在的无限列表。由于 SML 是 eager ,这需要以稍微迂回的方式完成。 我们先来看看
马丁·奥德斯基在他的书中写道: Class ::, pronounced “cons” for “construct,” represents non-empty lists. 和 The list
#lang racket 我需要从一个元素和一个列表创建一对 但是,当我执行 (cons 2 (list 1 2 3)) 时,我得到 (2 (1 2 3)),我想得到 ( 2 .(1 2 3))如何输
当我创建一个Java列表并且我希望头部是一个列表时,它应该打印[[-1,0],1,2,3,4]还是可以,它只保留子列表[-1 , 0] 作为两个独立的元素,例如 [-1, 0, 1, 2,3,4],以
我正在尝试使用 LINQ 按语句进行分组。我收到错误名称“con”在当前上下文中不存在。 在选择后的代码中,我试图获取 ActivityID 值,但列表“con”不可用。 List contribut
我想做的是让我的 html/php 代码在表格中显示来 self 的 MySQL 的数据。 它只连接到数据库,但我想我在以下位置遇到错误:$resultt=$con->query("SELECT Di
以下代码在 Green Hills C 编译器中导致错误(错误:type int * is incompatible with argument type const int*),而它仅产生警告并使用
我正在尝试通过在 LISP 中使用以下代码添加到一个空列表来构造一个唯一的元素列表: ;;;MEMSET - return T if an atom is a top-level member
嗯,最近开始学习lisp,在做一个小程序的时候发现了一点问题。问题是编写一个函数,如果名称还没有标题,则将其添加到名称中。我的代码是: (setf *man-names* '(carlos pablo
如何设置变量指向列表单元格? 我正在尝试编写一个宏来将列表中的所有值乘以一个值。这是我目前拥有的: (defmacro scale (areas scale) `(dotimes (n (list
我是一名优秀的程序员,十分优秀!