- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我开始阅读The Mother of All Monads ,并输入这个例子:
import Control.Monad.Cont
ex1 = do
a <- return 1
b <- return 10
return $ a+b
ghci> :l ContMonad.hs
[1 of 1] Compiling Main ( ContMonad.hs, interpreted )
ContMonad.hs:4:4:
No instance for (Monad m0) arising from a do statement
The type variable ‘m0’ is ambiguous
Relevant bindings include
ex1 :: m0 Integer (bound at ContMonad.hs:3:1)
Note: there are several potential instances:
instance Monad ((->) r) -- Defined in ‘GHC.Base’
instance Monad IO -- Defined in ‘GHC.Base’
instance Monad [] -- Defined in ‘GHC.Base’
...plus six others
In a stmt of a 'do' block: a <- return 1
In the expression:
do { a <- return 1;
b <- return 10;
return $ a + b }
In an equation for ‘ex1’:
ex1
= do { a <- return 1;
b <- return 10;
return $ a + b }
Failed, modules loaded: none.
最佳答案
问题是ex1
因为表达式适用于任何 monad,并且未指定使用的 monad。 ex1
的类型很可能是 ex1 :: (Num b, Monad m) => m b
但是,因为dreaded monomorphism restriction , GHC 无法推断出这种多态类型,因此结果不明确。
您可以通过给它一个显式类型签名或禁用单态限制来编译它:
{-# LANGUAGE NoMonomorphismRestriction #-}
ex1
至
IO Int
因为
extended default rules :
*Main> ex1
11
*Main> ex1 :: [Int]
[11]
*Main> ex1 :: Maybe Int
Just 11
关于haskell - 使用 ContT 构造函数创建新的 Monad Cont,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28934042/
Cont r a type 代表一个需要延续的函数 a->r并产生 r 类型的结果。所以延续和整个 Cont r a产生相同类型的结果 r 。 我的问题是:两个结果是否必须相同值,或者可以是 Cont
嘿,我正在尝试查询在连续列中具有最大值的单词。例如:如果单词“test1”在 cont 中的值为 5,而“test2”的值为 2,则“test1”将显示在第一个位置。明白了吗? 所以。我正在尝试这样做
想起我之前在此列表中加入了一个字段,用于方便提示管理员公司的产品列表是否有修改之类的状态字段,于是可以断定是加了此字段的原因。 首先,先看看我之前是如何写这个提示状态字段的,实体中加入
我在玩Cont描述的单子(monad)技巧here在 this SO question . 这个函数让你“跳回”到计算的早期,接受一个参数,这样你就可以做不同的事情: import Control.M
我在玩 CPS 和 Control.Monad.Cont并想知道我们通过注意一元结构获得了什么。对于这样的代码: sumOfSquares'cps :: Cont r Int -> Cont r In
我正在为 this question 提供答案我想到了使用 Cont monad 的想法。我对 Haskell 的了解不足以解释为什么这个程序不起作用 import Control.Monad.Con
我有一个任务:写一个函数evalCPS它评估由下面的 ADT 形式化的表达式,使用继续传递样式但没有 Cont Monad 或类似的东西。 data Expr a = Expr a :+: Expr
这就是 Cont monad 的定义方式: newtype Cont r a = Cont { runCont :: (a -> r) -> r } instance Monad (Cont r) w
我正在为 this question 提供答案我想到了使用 Cont monad 的想法。我对 Haskell 的了解不足以解释为什么这个程序不起作用 import Control.Monad.Con
我正在看一个带有 python-ptrace 的游戏。我不想与服务器断开连接,因此在附加到进程后,我立即调用 cont() 以允许它继续运行。 在这种状态下我仍然可以读取内存,但无法写入。 是否有办法
我在 Standard ML (SMLofNJ.Cont) 中阅读有关continuations的内容。我了解 callcc 和 throw 的作用,但无法理解 isolate 。文档说 Discar
我真的很难理解 callCC。我得到了延续的力量,我一直在我的一些项目中使用这个概念来创造很酷的概念。但是我从来不需要使用比 cont :: ((a->r)->r)-> Cont r a 更强大的东西
我正在尝试 Cont monad,并发现了以下问题。 首先构造一个无限列表并将所有元素提升到 Cont monad 使用序列操作在无限列表上获取 Cont monad。 例如,当我们尝试使用 head
我正在阅读this implementation Haskell 中的 Continuation,感觉比较棘手,很多时候,r 并不是那么重要,所以我们提供了reset,方便被替换。 所以我认为Cont
我正在用 Haskell 编写一个该死的解释器,我想出了一个我认为非常有趣的程序描述: data Program m = Instruction (m ()) (Program m)
我开始阅读The Mother of All Monads ,并输入这个例子: import Control.Monad.Cont ex1 = do a :l ContMonad.hs [1 o
我最近正在查看此页面: https://en.wikipedia.org/wiki/C_syntax#Iteration_statements有这样的代码片段: e1; while (e2) {
我最近正在学习 Herb Sutter 的“Exceptional C++”,我对他在第 6 项 - 临时对象中给出的特定建议深表怀疑。 他提出在以下代码中查找不必要的临时对象: string Fin
我遇到了一个问题。我们有一个干净的脚本用来清理旧文件,有时我们需要停止它,稍后再启动它。像下面的过程。我们在check.sh中使用kill -STOP $pid和kill -CONT $pid来控制c
我最近正在阅读 Herb Sutter 的“Exceptional C++”,我对他在第 6 项 - 临时对象中给出的特定建议表示严重怀疑。 他提出在以下代码中查找不必要的临时对象: string F
我是一名优秀的程序员,十分优秀!