- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试了解 monad 转换器,并且正在阅读 this page在 haskell wiki 上。
我感到困惑的代码如下:
isValid :: String -> Bool
isValid s = length s >= 5
getValidPassword :: MaybeT IO String
getValidPassword = do s <- lift getLine
guard (isValid s)
return s
askPassword :: MaybeT IO ()
askPassword = do lift $ putStrLn "Insert your new password:"
value <- getValidPassword
lift $ putStrLn "Storing in database..."
到目前为止一切顺利。我可以运行这个并且它有效。但现在,将 askPassword
更改为:
askPassword :: MaybeT IO ()
askPassword = do lift $ putStrLn "Insert your new password:"
value <- msum $ repeat getValidPassword
lift $ putStrLn "Storing in database..."
如果不满足有效性条件,这将反复等待我给出新的输入。我有点迷失它是如何做到的。 repeat
永远重复该操作,而 msum
只是 foldr mplus mzero
,这意味着它沿着列表行走并将值“添加”在一起。
为什么当我给出错误的输入时它不立即返回(返回值将为Nothing)。我想我没有看到决定何时停止和何时继续的逻辑嵌入在哪里。谢谢你的帮助。
最佳答案
嗯,Maybe
的 msum
应该在第一次成功尝试时停止,而不是在第一次失败时停止。
关于haskell - MaybeT 的这种特殊用途是如何运作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23140098/
我正在尝试了解 monad 转换器,并且正在阅读 this page在 haskell wiki 上。 我感到困惑的代码如下: isValid :: String -> Bool isValid s
我试图通过在 ghci 中运行一些示例来理解 MaybeT: λ: import Control.Monad.Trans.Maybe λ: let x = return $ 42 :: MaybeT
在 IO 计算中工作,我最终得到了 case mbValue of … 的阶梯。 s 并发现我应该使用 Maybe monad 来简化代码。因为它在 IO 内计算,我需要得到 IO值,我使用了 May
我有一个程序。 import Control.Monad import Control.Monad.Identity import Control.Monad.Trans.Maybe import S
我有一个使用 Control.Monad.Random 的简单函数来创建一个可以对随机数进行采样的函数。 import Control.Monad.Random import Data.R
idris 有没有MaybeT来自 Haskell 还是我应该使用其他东西?我正在尝试使用 IO (Maybe a) 类型的许多值进行计算.怎么能结合Maybe和 IO到 Idris 中的单个 mon
在https://en.wikibooks.org/wiki/Haskell/Monad_transformers , 我明白了 newtype MaybeT m a = MaybeT { runMa
Haskell 如何知道每个 return 表达式哪个是正确的 monad 实例? newtype MaybeT m a = MaybeT { runMaybeT :: m (Maybe a) } i
查看 MaybeT: λ: import Monad.Trans λ: import Monad.Trans.Maybe λ: :t MaybeT MaybeT :: m (Maybe a) -> M
在https://en.wikibooks.org/wiki/Haskell/Monad_transformers , 我明白了 newtype MaybeT m a = MaybeT { runMa
这是一个与 Why doesn't Option have a fold method? 类似的问题,但对于函数式java。 如果选项为 None,我想执行一些副作用。除了if maybeT.isNo
重新访问我的 MaybeT 练习后,我收到警告说我也应该有 Applicative 实例。我试图实现它,但因为我找不到使用 Applicative m 将 m x 应用到 m f 的方法而陷入困境。我
对于我之前关于链接失败的问题,Michael Snoyman 建议我使用 MaybeT运行它们,所以如果它们中的任何一个失败,它就会短路到 Nothing . 我的印象是runDb在事务中运行所有内容
查看 Monad 的 MaybeT 实例中 fail 的源代码: instance (Monad m) => Monad (MaybeT m) where fail _ = MaybeT (r
具体来说,假设我有这个 monadT 堆栈: type MHeap e ret = MaybeT ( StateT [e] Identity ) ret 和一个方便的 runMheap 函数: run
我一直在使用Haxl monad(在此处描述:http://www.reddit.com/r/haskell/comments/1le4y5/the_haxl_project_at_facebook_
如果我为 Identity 定义单子(monad)变压器类型,可以推导出Show实例。 newtype IdentityT f a = IdentityT { runIdentityT :: f
说我有一些foo :: Maybe Int例如,我想将它与 bar :: Int -> MaybeT (Writer String) Int 绑定(bind),这样做的惯用方法是什么? 我可以定义自己
简短版本:当我使用 runMaybeT 时然后runState在 MaybeT (State ) () 类型的单子(monad)上,即使 Maybe 看起来也没有发生状态变化。结果等于Just ()
我正在尝试 MaybeT monad,特别是 MaybeT Identity String import Control.Monad.Trans.Maybe import Control.Monad.
我是一名优秀的程序员,十分优秀!