- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我经常读到惰性与非严格不同,但我发现很难理解其中的区别。它们似乎可以互换使用,但我知道它们有不同的含义。我希望能得到一些帮助来理解其中的差异。
我有一些关于这篇文章的问题。我将在本文末尾总结这些问题。我有一些示例片段,我没有测试它们,我只是将它们作为概念呈现。我添加了引号,以免您查找它们。也许它会对以后遇到同样问题的人有所帮助。
A function f is said to be strict if, when applied to a nonterminatingexpression, it also fails to terminate. In other words, f is strictiff the value of f bot is |. For most programming languages, allfunctions are strict. But this is not so in Haskell. As a simpleexample, consider const1, the constant 1 function, defined by:
const1 x = 1
The value of const1 bot in Haskell is 1. Operationally speaking, sinceconst1 does not "need" the value of its argument, it never attempts toevaluate it, and thus never gets caught in a nonterminatingcomputation. For this reason, non-strict functions are also called"lazy functions", and are said to evaluate their arguments "lazily",or "by need".
-A Gentle Introduction To Haskell: Functions
我真的很喜欢这个定义。这似乎是我能找到的最好的理解严格的方法。 const1 x = 1
也是懒惰的吗?
Non-strictness means that reduction (the mathematical term forevaluation) proceeds from the outside in,
so if you have (a+(bc)) then first you reduce the +, then you reducethe inner (bc).
-Haskell Wiki: Lazy vs non-strict
Haskell Wiki 真的让我很困惑。我理解他们所说的关于顺序的内容,但我不明白如果通过 _|_
,(a+(b*c))
将如何非严格地评估?
In non-strict evaluation, arguments to a function are not evaluatedunless they are actually used in the evaluation of the function body.
Under Church encoding, lazy evaluation of operators maps to non-strictevaluation of functions; for this reason, non-strict evaluation isoften referred to as "lazy". Boolean expressions in many languages usea form of non-strict evaluation called short-circuit evaluation, whereevaluation returns as soon as it can be determined that an unambiguousBoolean will result — for example, in a disjunctive expression wheretrue is encountered, or in a conjunctive expression where false isencountered, and so forth. Conditional expressions also usually uselazy evaluation, where evaluation returns as soon as an unambiguousbranch will result.
-Wikipedia: Evaluation Strategy
Lazy evaluation, on the other hand, means only evaluating anexpression when its results are needed (note the shift from"reduction" to "evaluation"). So when the evaluation engine sees anexpression it builds a thunk data structure containing whatever valuesare needed to evaluate the expression, plus a pointer to theexpression itself. When the result is actually needed the evaluationengine calls the expression and then replaces the thunk with theresult for future reference....
Obviously there is a strong correspondence between a thunk and apartly-evaluated expression. Hence in most cases the terms "lazy" and"non-strict" are synonyms. But not quite.
-Haskell Wiki: Lazy vs non-strict
这似乎是 Haskell 的具体答案。我认为惰性意味着thunk,非严格意味着部分评估。这样的比较是不是太简单化了? lazy 是否总是意味着 thunk,而 non-strict 总是意味着部分评估。
In programming language theory, lazy evaluation or call-by-need1 isan evaluation strategy which delays the evaluation of an expressionuntil its value is actually required (non-strict evaluation) and alsoavoid repeated evaluations (sharing).
我知道大多数人都会说在学习函数式语言时忘记命令式编程。但是,我想知道这些是否符合非严格、惰性、两者兼有或两者都没有的资格?至少它会提供一些熟悉的东西。
短路
f1() || f2()
C#、Python 等具有“yield”的语言
public static IEnumerable Power(int number, int exponent)
{
int counter = 0;
int result = 1;
while (counter++ < exponent)
{
result = result * number;
yield return result;
}
}
回调
int f1() { return 1;}
int f2() { return 2;}
int lazy(int (*cb1)(), int (*cb2)() , int x) {
if (x == 0)
return cb1();
else
return cb2();
}
int eager(int e1, int e2, int x) {
if (x == 0)
return e1;
else
return e2;
}
lazy(f1, f2, x);
eager(f1(), f2(), x);
我知道答案就在我面前,拥有所有这些资源,但我无法捕获它。看起来这个定义太容易被认为是隐含的或明显的而被忽视。
我知道我有很多问题。请随意回答您认为相关的任何问题。我添加了这些问题以供讨论。
const1 x = 1
也是懒惰的吗?非常感谢!
最佳答案
非严格和惰性虽然非正式地可以互换,但适用于不同的讨论领域。
非严格指的是 semantics :表达式的数学含义。非严格适用的世界没有函数的运行时间、内存消耗甚至计算机的概念。它只是讨论域中的哪些类型的值映射到共域中的哪些类型的值。特别是,严格函数必须将值 ⊥(“bottom”——有关更多信息,请参阅上面的语义链接)映射到 ⊥;允许非严格函数不执行此操作。
惰性指的是操作行为:代码在真实计算机上执行的方式。大多数程序员从操作角度考虑程序,所以这可能就是您的想法。惰性求值是指使用 thunk 的实现——指向代码的指针,这些代码在第一次执行时被值替换。注意这里的非语义词:“指针”、“第一次”、“执行”。
惰性求值会产生不严格的语义,这就是为什么这些概念看起来如此接近的原因。但正如 FUZxxl 指出的那样,惰性并不是实现非严格语义的唯一方法。
如果您有兴趣了解有关此区别的更多信息,我强烈推荐上面的链接。阅读这本书是我对计算机程序含义概念的转折点。
关于haskell - 非严格和惰性有何不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7140978/
在 Windows 世界中,什么是正确的名称。具有导出函数的老式 C++ DLL?不是 COM DLL,也不是 .NET DLL。我们以前通过调用 LoadLibrary() 和 GetProcAdd
目前我正在使用javaEE7,我有一个场景如下。在我的 JSF Web 应用程序中,我有一个事件监听器(不是 JSF 事件),当事件调用时,它会执行某些操作,然后将这些信息更新到我的 Web 应用程序
这不是 AJAX 请求/响应回调问题... 我正在使用 Dojo 1.5 构建网格。我正在尝试 dojo.connect具有功能的扩展/收缩按钮。我的问题是 grid.startup()在创建实际 D
非 Webkit Opera 是 very specific在某些功能中,因此通常通过 JavaScript 检测到 the following way . 但是,Opera Next 几乎是 Goo
我已查看以下链接中给出的所有日志,但未能找到 IP 地址: https://developer.couchbase.com/documentation/server/3.x/admin/Misc/Tr
我有一个命令行程序,它根据一组源文件生成一个我想在我的 Android gradle 构建 (A) 中使用的 jar 文件。这个命令行程序只是将一个 jar 文件存储在磁盘上的一个目录中。 我如何创建
下面的 htaccess 命令将所有非 www 转移到 http www RewriteEngine On RewriteCond %{HTTP_HOST} !^www\. RewriteRule ^
我正在使用自定义链接器脚本将内核镜像分为两部分。第一个是普通代码和数据,第二个是初始化代码和不再需要时将被丢弃的数据。初始化部分也不像内核本身那样在地址空间之间共享,因此如果 fork() 仍然存在(
这个问题在这里已经有了答案: Several unary operators in C and C++ (3 个答案) What is the "-->" operator in C++? (29
假设我有一个类设置如下: class A { public: virtual void foo() { printf("default implementation\n"); } }; c
#include using namespace std; int main(int argc, char *argv[]) { int i=-5; while(~(i)) {
近期,百度搜索引擎变化无常,很多企业站、行业站、门户站、论坛等站点遭到了降权,特别是比比贴分类信息网直接遭到了拔毛,这对于广大站长来说是一种打击,也是各个企业、行业的打击。 至今,很多网站已经恢复
我现在正在使用 IBM TPM v1332 + IBM TSS v1470 并尝试将一些基本关键字/密码存储到 TPM 上的非 volatile 内存中。我找到了两种方法。一种是创建一个密封对象并使用
我的 PHP 脚本中有一个正则表达式,如下所示: /(\b$term|$term\b)(?!([^)/iu 这与 $term 中包含的单词匹配,只要前后有单词边界并且它不在 HTML 标记内即可。 但
我想显示用户名称地址(请参阅 www.ipchicken.com ),但我唯一能找到的是 IP 地址。我尝试了反向查找,但也没有用: IPAddress ip = IPAddress.Parse(th
只有 UI 线程能够显示到屏幕上,还是其他线程也可以这样做? 最佳答案 不,您只能直接从 UI 线程访问 UI,但您可以编码来自其他线程的结果,例如使用 Control.Invoke 或 contro
我正在使用现代 Excel 滚动条(不是旧的 ActiveX 类型,即开发人员 > 插入 > 表单控件 > 滚动条)并且想检测它的值何时更改。我找不到有关此类对象的更改事件的任何信息。您可以在单击时分
当我使用这段代码时 IE 6 确实正确使用了指定的样式表,但所有其他浏览器在应该使用基本上声明的样式表时会忽略这两种样式表,如果您不是 IE,请使用此样式表。 有什么想法吗? 最佳答案 n
我想指定 2 mssql 表之间的关系。 付款类别和付款。 paymentcategory.id 加入 payout.category 列。 在 payout.json 模型中 我指定为外键:id,
我正在尝试制作非 volatile UDF,但似乎不可能。因此,这是我非常简单的test-UDF: Option Explicit Dim i As Integer Sub Main() i = 0
我是一名优秀的程序员,十分优秀!