我有一个问题来自对我的问题的回答:haskell Either and Validation Applicative
我的密码贴在那里了。
它涉及*>排序操作符的使用,而不是<*>应用运算符。
基于https://hackage.haskell.org/package/base-4.15.0.0/docs/Control-Applicative.html#v:-42--62-的解释,我理解*>序列的动作,放弃了第一个参数的值。因此,对于我的代码,我尝试了fail6 = fail2 *> success,它可以工作,但它不应该工作,因为第一个参数的值,即fail2,应该被丢弃。为什么fail6能工作?
fail6的输出为Failure [MooglesChewedWires,StackOverflow]。
发布于 2021-04-14 10:58:05
“丢弃结果”是指应用程序的结果。对于一个Either来说,这意味着一个Right y。因此,(*>)相当于:
(*>) :: Applicative f => f a -> f b -> f b
(*>) f g = liftA2 (const id) f g或以另一种形式:
(*>) :: Applicative f => f a -> f b -> f b
(*>) f g = (const id) <$> f <*> g因此,它运行两个操作并返回第二个结果,但这是在"Applicative上下文“中。
例如,对于一个Either,这被实现为:
实例应用程序( a),其中纯=右e <*> _=左e_ <*>左e=左e右f <*>右x=右(f x)
这意味着(*>)是为Either实现的,如下所示:
-- (*>) for Either
(*>) :: Either a b -> Either a c -> Either a c
Left x *> _ = Left x
_ *> Left x = Left x
Right _ *> Right x = Right x或相当于:
-- (*>) for Either
(*>) :: Either a b -> Either a c -> Either a c
Left x *> _ = Left x
_ *> x = x如果第一个操作数是Right …,它将返回第二个操作数,如果第一个操作数是Left x,则返回Left x。
发布于 2021-04-14 18:20:04
“结果”是个相当模糊的词,不是吗?当我们谈到Functor、Applicative和Monad时,我们倾向于在某种“上下文”中引用零或更多的值。所以
IO a:是产生a.[a]:类型值的I/O计算,一个类型为零或多个值的列表,或者类型为a.Either e a:的一个元素,就像Maybe a一样,但没有a的大小写是用e.(x, a):类型的东西“修饰”,而a类型的值是用一个x类型的“修饰”。Identity a:类型为a的值,没有任何上下文。当你“放弃结果”时,这意味着你关心的是上下文,而不是价值。所以:
I/O做了什么?列表中有多少元素?Nothing
Just是,decoration?
,
。
https://stackoverflow.com/questions/67090168
复制相似问题