- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在学习 UPenn 的 CS194,目前正在学习第 7 课,Monads。在我看到序列函数的实现并开始四处探索之前,我以为我对 Monads 有了很好的掌握。
sequence :: Monad m => [m a] -> m [a]
sequence [] = return []
sequence (ma:mas) = do
a <- ma
as <- sequence mas
return (a:as)
return []
的类型是:return [] :: Monad m => m [t]
.在同一课的前面,Monad
[]
的实例将返回定义为:return x = [x]
.这如何导致类型签名m [t]
为 return []
? a <- ma
. a
的类型是什么在这里,假设我用 [Just 5, Just 9]
调用序列?由 Monad
Maybe
的实例定义:Just x >>= k = k x
x
, 或 a
在 sequence
的情况下将是 Num
.但它一定是一个Monad
的 Num
.怎么样x
成为Num
的monad在这里当 Just x
来自 Maybe
的实例定义好像在拉x
出Just
? 最佳答案
return []
的类型是 Monad m => m [t]
- 在这里,[]
是 [t]
的一个实例,即某个任意类型的列表(该类型是任意的,因为它是空列表,因此无论如何都没有该类型的实例)。如果替换列表 monad,则类型为 return
是 t -> [t]
, 和 return []
yield [[]]
.令人困惑的是,monad 和包含的值都是列表。return
的类型一般是Monad m => t -> m t
.如果你专门研究列表,你会得到 t -> [t]
,所以列表类型代替了 m
.列表的特殊语法使这更令人困惑;如果你使用maybe monad,专门的返回类型为t -> Maybe t
,因此您可以清楚地看到 m
被 Maybe
取代.在maybemonad中,return []
的类型是 Maybe [t]
: monad 现在包装了一些列表。return []
的类型是 Monad m => m [t]
,由 monad 包装的列表。如果你使用 list monad,你可以替换 m
使用列表构造函数并获得 [[t]]
,这是正确的类型。
至于第二个问题,你为什么认为a
必须是单子(monad)?
在评论中澄清后编辑
在示例中调用 sequence [Just 5, Just 9]
你给了,单子(monad)可能是,而不是列表;该列表是 sequence
类型要求的普通列表.请记住,它需要一个 [m a]
作为输入。为您提供 Num a => [Maybe a]
作为输入,这使得 monad Maybe
,结果类型为 Num a => Maybe [a]
. sequence
将可选值列表转换为可选列表。这意味着在 sequence
的第一种情况下, return []
适用于Maybe
的 return
并表示 Just []
.这是有道理的,因为调用 sequence []
也许 monad 应该返回 Just []
.
现在,在第二种情况的 do-block 中,我们有一堆变量,它有助于找出每个变量的类型。对于 Maybe
的具体情况,我会这样做和 Int
对于数字;获取泛型归结为简单地替换 Maybe
与 m
和 Int
与 a
在所有这些情况下,并添加约束。
整个输入的类型为 [Maybe Int]
.第二种情况与 (ma:mas)
匹配,从列表中选取第一个元素。所以ma
具有列表元素的类型,Maybe Int
, 而 mas
是列表的其余部分,因此类型为 [Maybe Int]
.
在 do-block 中,ma
用箭头符号展开,结果是 a
,因此其类型为 ma
去掉monad,即Int
.
然后,sequence
与输入的其余部分一起递归调用,mas
, 类型为 [Maybe Int]
.代入sequence
的类型显示结果类型为 Maybe [Int]
.该值再次展开,因此目标 as
有类型 [Int]
.
在最后一行,a
(类型 Int
)附加到 as
(输入 [Int]
),产生更长的列表( [Int]
)。结果给return
,将其包裹在 Just
中( Maybe [Int]
) 匹配结果类型 sequence
.
顺便说一句,如果您想通过 do-blocks 详细跟踪类型,您应该首先使用 lambda 将它们脱糖为正常组合。
关于haskell - Haskell 的序列函数问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34903120/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!