- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Haskell 有一个名为 seq
的神奇函数,它接受任何类型的参数并将其简化为弱头范式 (WHNF)。
我读过一些资料[但我现在不记得他们是谁了...],它们声称“多态 seq
很糟糕”。他们在哪些方面“不好”?
类似地,还有 rnf
函数,它将参数简化为普通形式 (NF)。但是this是一个类方法;它不适用于任意类型。对我来说,“显而易见”的是,人们可以改变语言规范,将其作为内置原语提供,类似于 seq
。据推测,这比仅仅拥有 seq“更糟糕”。这是什么情况?
最后,有人建议给 seq
、rnf
、par
和类似的类型与 id
相同的类型函数,而不是现在的 const 函数,将是一个改进。怎么会这样?
最佳答案
据我所知,多态 seq
函数不好,因为它削弱了自由定理,或者换句话说,一些在没有 seq
的情况下有效的等式不再有效与seq
。例如,等式
map g (f xs) = f (map g xs)
适用于所有函数 g::tau -> tau'
、所有列表 xs::[tau]
以及所有多态函数 f::[a ] -> [a]
。基本上,这种等式表明 f
只能对其参数列表的元素进行重新排序,或者删除或重复元素,但不能发明新元素。
说实话,它可以发明元素,因为它可以将非终止计算/运行时错误“插入”到列表中,因为错误的类型是多态的。也就是说,这种等式已经在像 Haskell 这样没有 seq
的编程语言中被破坏了。以下函数定义提供了该方程的反例。基本上,在左侧g
“隐藏”了错误。
g _ = True
f _ = [undefined]
为了修复方程,g
必须严格,也就是说,它必须将错误映射到错误。在这种情况下,等式再次成立。
如果添加多态 seq
运算符,方程会再次破裂,例如下面的实例化就是一个反例。
g True = True
f (x:y:_) = [seq x y]
如果我们考虑列表xs = [False, True]
,我们有
map g (f [False, True]) = map g [True] = [True]
但是,另一方面
f (map g [False, True]) = f [undefined, True] = [undefined]
也就是说,你可以使用seq
使列表中某个位置的元素依赖于列表中另一个元素的定义。如果g
是总的,则等式再次成立。如果您对自由定理感兴趣,请查看 free theorem generator ,它允许您指定是否正在考虑一种有错误的语言,甚至是一种带有 seq
的语言。尽管这似乎不太实际,但 seq
破坏了一些用于提高函数程序性能的转换,例如 foldr
/build
存在 seq
时融合失败。如果您对 seq
存在下的自由定理的更多细节感兴趣,请查看 Free Theorems in the Presence of seq .
据我所知,当多态 seq
添加到语言中时,它会破坏某些转换。然而,替代方案也有缺点。如果您添加基于类型类的 seq
,如果您在深处的某处添加 seq
,则可能需要向程序添加大量类型类约束。此外,省略 seq
并不是一个选择,因为我们已经知道存在可以使用 seq
修复的空间泄漏。
最后,我可能会错过一些东西,但我不明白 a -> a
类型的 seq
运算符如何工作。 seq
的线索是,如果另一个表达式被评估为 head 范式,它就会评估一个表达式为 head 范式。如果 seq
的类型为 a -> a
,则无法使一个表达式的计算依赖于另一个表达式的计算。
关于haskell - 为什么 seq 不好?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12687392/
非常简单的应用程序 - 您可以复制 - 粘贴 - 运行。主要只是“创建”应用程序。 - 这不是问题(可能) #include #include #include #include typede
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 6 年前。 Improve t
Haskell 有一个名为 seq 的神奇函数,它接受任何类型的参数并将其简化为弱头范式 (WHNF)。 我读过一些资料[但我现在不记得他们是谁了...],它们声称“多态 seq 很糟糕”。他们在哪些
我正在编写一个脚本,该脚本应该在一堆服务器周围运行并从中选择一堆数据,包括本地服务器。选择我需要的数据所需的 SQL 非常复杂,所以我正在编写一种临时 View ,并使用 OPENQUERY 语句来获
考虑以下代码: case class Vector3(var x: Float, var y: Float, var z: Float) { def add(v: Vector3): Unit =
我正在读这个SO post关于守护线程,答案底部的引述是: But joining a demonized thread opens most likely a whole can of troubl
在阅读有关 Google webtool 工具包的内容时,看到一条声明说“同步 RPC 不好”。他们有什么理由吗?我能想到的一个很好的理由是,对最终用户的响应可能会受到远程服务器延迟或网络问题的影
我有以下 HTML: A Simple Sample Web Page By Sheldon Brown Demonstrating a few HTML feat
我正在做一项简单的任务,但我陷入困境...... output 我需要使第一行与其他所有内容保持一致,但无论我做什么,它都不想接受空格。那么,我应该纠正什么以及为什么?谢谢 public static
我在系统中有一个类,其目的列为“这可以是从午夜算起的秒数。或者带有日期的时间。”我试图解释这有多糟糕,但我无法理解我的观点。有没有人对如何解决这个问题有任何想法。 http://code-slim-j
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: When are C++ macros beneficial? Why is #define bad and
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
始终建议通过将所有代码放在 JS 文件中来避免内联 Javascript 代码,该文件包含在所有页面中。我想知道,这是否不会导致繁重的页面出现性能问题。 例如,假设我们有几十个这样的函数 functi
我主要在 AngularJS 中进行开发,最近我正在研究 Vue.js 并阅读它的指南,在它提到的一页上: By default, all props form a one-way-down bind
我正在构建一个本地化目录,但遇到了设计难题。现在,目录存储一个 Dictionary存储翻译,其中 IString可以是两种类型:Singular或 Plural .这是 IString 的简化版本:
对于我的矩阵类,我做了: template class Matrix { private: std::array, Height> Elements; stat
MSDN documentation说 public class SomeObject { public void SomeOperation() { lock(this) {
建议不要在 Python 中使用 import *。 谁能分享一下原因,这样我下次就可以避免了? 最佳答案 因为它会将很多东西放入您的命名空间(可能会影响之前导入的一些其他对象,而您不会知道它)。 因
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
G'day, 这与my question on star developers有关并到 this question regarding telling someone that they're wri
我是一名优秀的程序员,十分优秀!