- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何评估 1:(2:(3:[]))?
在到达 [1,2,3] 之前采取哪些重写步骤?
是吗
1:(2:([3])
1:([2,3])
[1,2,3]
还是别的什么?上面描述的方法是唯一的方法吗?或者还有其他方法吗?
最佳答案
Haskell 在这里没有任何实际计算的内容,因为 :
是列表的构造函数。当您编写类似 [1, 2, 3]
的内容时,编译器首先将其脱糖为 1 : 2 : 3 : []
和 这是它在内存中的表示。这就像询问 Just 1
的评估顺序是什么。没有评估顺序,因为它已经处于“最评估”形式,也称为正常形式。
对于列表,正常形式是在空列表前面组合在一起的元素。如果有帮助,您可以将列表定义为
data [a] = [] | a : [a]
或者另一种选择
data List a = Empty | Cons a (List a)
当你进行模式匹配时
f (x:xs) = ...
这相当于进行模式匹配
f (Cons x xs) = ...
唯一真正的区别是使用的名称。
<小时/>所以我想你问题的答案是你的评估是向后的,你不会从 1:2:3:[]
到 [1, 2, 3 ]
,您会从 [1, 2, 3]
转到 1:2:3:[]
,尽管此步骤发生在脱糖过程中。至于列表推导式,使用 >>
和 >>=
等一元函数将它们脱糖为映射和过滤器。当您看到类似 [1..10]
的内容时,它实际上使用 Enum
实例作为其元素,并脱糖为 fromEnumTo
和类似的功能。所有这些函数都适用于 :
和 []
级别的列表,因此它们只是使用列表类型的构造函数,就像使用任何其他数据类型一样.
作为证据,如果我有代码
module Foo where
x :: [Int]
x = [1, 2, 3]
我用ghc -c Foo.hs -ddump-ds
编译它,我会得到
Foo.x :: [GHC.Types.Int]
[LclIdX]
Foo.x =
GHC.Types.:
@ GHC.Types.Int
(GHC.Types.I# 1)
(GHC.Types.:
@ GHC.Types.Int
(GHC.Types.I# 2)
(GHC.Types.:
@ GHC.Types.Int (GHC.Types.I# 3) (GHC.Types.[] @ GHC.Types.Int)))
其中有很多额外的元数据,所以让我们删除所有额外的类型注释、模块名称和其他噪音:
Foo.x :: [Int]
Foo.x = GHC.Types.: 1 (GHC.Types.: 2 (GHC.Types.: 3 []))
或者甚至更多删除
x :: [Int]
x = : 1 (: 2 (: 3 []))
请注意,在核心中(GHC 将 Haskell 源代码编译为所用的 3 种中间语言之一),我们不需要以前缀形式围绕运算符使用括号。但很容易看出,一旦所有内容都被脱糖,它就简单地表示为一个组合在一起的列表。
但是等等!我以为you said that the parens weren't needed ?当它采用中缀形式时确实如此,但现在 :
被用作前缀函数。很容易看出,使用前缀时,需要括号,特别是如果将 :
替换为 Cons
并将 []
替换为 Empty
:
x = Cons 1 (Cons 2 (Cons 3 Empty))
因为以下内容不会进行类型检查。它使它看起来像 Cons
需要 6 个参数!
x = Cons 1 Cons 2 Cons 3 Empty
关于haskell - 简单列表创建中的评估顺序是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24853373/
如标题所示,ans_list是一个答案列表,ans_index是一个数字(答案在词汇表中的索引,但与atm无关) 这里生成的 tree.anslist 是什么? (例如,仅针对第一个),忽略迭代。 f
我目前将用户的输入存储在逗号分隔的列表中,如下所示: Userid | Options 1 | 1,2,5 用户在一个数组形式中勾选一组选项,然后用逗号连接起来 1,2,5 然后 MySQ
我目前将用户的输入存储在逗号分隔的列表中,如下所示: Userid | Options 1 | 1,2,5 用户在一个数组形式中勾选一组选项,然后用逗号连接起来 1,2,5 然后 MySQ
我想知道如何完全展平列表和包含它们的东西。除其他外,我想出了一个解决方案,它可以将具有多个元素的东西滑倒并将它们放回原处,或者在滑倒后将具有一个元素的东西拿走。 这与 How do I “flatte
我想知道如何完全展平列表和包含它们的东西。除其他外,我想出了一个解决方案,它可以将具有多个元素的东西滑倒并将它们放回原处,或者在滑倒后将带有一个元素的东西拿走。 这与 How do I “flatte
这个问题已经有答案了: Convert nested list to 2d array (3 个回答) 已关闭 7 年前。 java中有没有快捷方式可以转换 List> 到 String[][] ?
我在排序时遇到问题 List> 。我创建了一个自定义比较器,在其中编写了对数据进行排序的代码。 public class CustomComparator implements Comparator
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Java Generics: Cannot cast List to List? 我只是想知道为什么下面的java代
试图想出一个 LINQy 方法来做到这一点,但我什么也没想到。 我有一个对象列表<>,其中包含一个属性,该属性是逗号分隔的字母代码列表: lst[0].codes = "AA,BB,DD" lst[1
假设我有这些任务: points = [] point = (1, 2) 我怎么会这样做: points += point 它工作得很好,并且给了我点 = [1, 2]。但是,如果我这样做: poin
如何在 scala 中将 List[Task[List[Header]]] 类型转换为 Task[List[Header]]。 我有一个方法返回 Task[List[Header]] 并多次调用 do
如何在 Java 中查找二维列表的元素? 我有一个参数为 List> 的函数我想知道如何找到这个列表的行和列。 最佳答案 如果你喜欢 List> obj 然后你就可以像这样访问 obj.get(cur
分配 List到 List工作正常。 分配 List>到 List>不编译。 代码 public class Main { public static void main(String[] a
我正在用 Java 编写一个方法,该方法必须接收并迭代 Serializable 的 List。 有什么区别: public void myMethod(List list) { } 和 public
我看到很多人想用 mvvm 更新网格/列表/树的一部分,但他们不想刷新整个列表。 对于所有遇到此问题的人,我做了以下示例。 希望这对你有用。 最佳答案 这是一个简单的例子。整个代码中最重要的是: Bi
我正在为现有的 C++ 库编写包装器,该库使用列表,其中 T 是自定义结构。我被建议使用 vector 而不是列表,但我试图避免修改库。 为了更好地理解这个场景,我做了一个简单的应用程序,使用一个列表
List list List list 这两种声明有什么区别吗? 谢谢, 最佳答案 是的。 List可以包含所有派生自 Base 的不同事物的混合物. List包含同质项(从某种意义上说,它们必须全部
有人可以尽可能详细地解释以下类型之间的区别吗? List List List 让我更具体一点。我什么时候想使用 // 1 public void CanYouGiveMeAnAnswer(List l
我有一个元组列表,每个元组都是一对列表。所以我的数据看起来像: mylist = [(['foo', 'bar'], ['bar', 'bar']),(['bar', 'bar'],['bar', '
也许是一个时髦的标题,但我遇到了以下问题: 给定一个类型为 (a * b) list 的列表,我想创建一个类型为 (a * b list) list 的新列表。一个例子: 给定列表 let testL
我是一名优秀的程序员,十分优秀!