- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我正确理解 Haskell 中的 ST monad,runST
以巧妙的方式使用 2 级类型,以确保计算在转义 monad 时不会引用任何其他线程。
我有一种带有 Hindley-Milner 类型系统的玩具语言,我的问题如下:是否可以使用用于键入 runST
应用程序的临时规则来扩展 HM 类型系统,以便ST monad 是可以安全逃脱的,无需引入 2 级类型?
更准确地说,runST
的类型为 forall s a。 ST s a -> a
(即,rank-1)并且类型规则将首先尝试以与 HM 在 let 表达式中概括类型相同的方式概括计算类型,但如果 s
类型变量被发现被绑定(bind)。
与 vanilla HM 相比,上述内容仅限制接受的程序,所以看起来不错,但我不确定。这行得通吗?
最佳答案
万一问题的评论不完全清楚,您需要的判断是
这当然与 Hindley-Milner 附带的其他常见打字判断结合起来。 。有趣的是,我们最终不需要为任何引入 ST
类型的东西制定特殊规则,因为这些都不需要等级 2 的类型签名:
newSTRef :: a -> ST s (STRef s a)
readSTRef :: STRef s a -> ST s a
writeSTRef :: STRef s a -> a -> ST s ()
...
关于haskell - 带有 Hindley-Milner 类型系统的 runST,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39725024/
我发誓曾经有一件T恤出售,上面写着不朽的文字: 哪一部分 你不明白吗? 就我而言,答案是......全部! 特别是,我经常在 Haskell 论文中看到这样的符号,但我不知道它的含义。我不知道它应该是
考虑以下程序(在 Haskell 中,但可以是任何 HM 推断的语言): x = [] y = x!!0 使用 HM(或通过运行编译器),我们推断: x :: forall t. [t] y :: f
在 Haskell 中,我们可以编写以下数据类型: data Fix f = Fix { unFix :: f (Fix f) } 类型变量f有种* -> * (即它是一个未知类型的构造函数)。因此,
let a = b in c可以被认为是 (\a -> c) b 的语法糖。 ,但在一般的打字设置中,情况并非如此。例如,在米尔纳微积分 let a = \x -> x in (a True, a 1
我正在制作一种强类型玩具函数式编程语言。它使用 Hindley Milner 算法作为类型推断算法。 实现算法时,我有一个问题是如何推断相互递归函数的类型。 let rec f n = if n ==
我正在阅读关于 Hindley–Milner Type Inference 的维基百科文章试图从中找出一些道理。到目前为止,这是我所理解的: 类型分为单型或多型。 Monotype 进一步分类为类型常
我试图推断以下表达式的类型: let rec fix f = f (fix f) 应指定类型(a -> a) -> a 使用自下而上算法(在概括hindley-milner类型推理算法中描述)并添加以
我正在寻找关于著名 Damas-Hindley-Milner algorithm 的信息为函数式语言进行类型推断,尤其是关于实现的信息。 我已经知道如何执行 Algorithm W ,但我听说最近的新
当存在重载函数时,Hindley-Milner 算法如何工作? 以简单的形式(没有重载),它看起来很干净: y = arr[x1] //it's Generic. x1: int, arr: T[],
我正在尝试通过用我常用的语言 Clojure 实现算法 W 来自学 Hindley-Milner 类型推理。我遇到了 let 推理的问题,我不确定我是否做错了什么,或者我期望的结果是否需要算法之外的东
如果我正确理解 Haskell 中的 ST monad,runST 以巧妙的方式使用 2 级类型,以确保计算在转义 monad 时不会引用任何其他线程。 我有一种带有 Hindley-Milner 类
我正在尝试通过用我常用的语言 Clojure 实现算法 W 来自学 Hindley-Milner 类型推理。我遇到了 let 推理的问题,我不确定我是否做错了什么,或者我期望的结果是否需要算法之外的东
我读到 Rust 使用 Hindley-Milner 有很好的类型推断。 Rust 也有可变变量,据我所知,当 HM 算法处理可变性时必须有一些约束,因为它可能过度泛化。以下代码: let mut a
我正在开发一个用 Java 编写的基于数据流的简单系统(想象它就像一个 LabView 编辑器/运行时)。用户可以在编辑器中将 block 连接在一起,我需要类型推断来确保数据流图是正确的,然而,大多
我无法理解维基百科上给出的 HM 系统的 letrec 定义,这里:https://en.wikipedia.org/wiki/Hindley%E2%80%93Milner_type_system#R
下'What is Hindley Milner'它指出: Hindley-Milner is a restriction of System F, which allows more types b
PyPy 是否在编译时进行静态类型检查以在编译时捕获类型错误?如果不是,像 HM 类型推断这样的东西是否有助于在编译时捕获这些错误? 最佳答案 否 在两个帐户上。 (我假设 PyPy 是指具有 JIT
我最近一直在学习 λ 演算。我理解无类型和有类型 λ 演算之间的区别。但是,我不太清楚 之间的区别。 Hindley-Milner 型系统 和 类型化 λ 演算 .是关于parametric poly
Hindley-Milner 是一个类型系统,它是许多众所周知的函数式编程语言的类型系统的基础。 Damas-Milner 是一种在 Hindley-Milner 类型系统中推断(推导出?)类型的算法
有人曾经在 SML 中向我展示了一个小技巧,他们在他们的 REPL 中写出了大约 3 或 4 个函数,最后一个值的结果类型非常长(就像许多页面滚动很长)。 有谁知道什么代码会生成这么长的类型,或者是否
我是一名优秀的程序员,十分优秀!