- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 his answer's comment section , Apocalisp 声明如下:
Well, you did ask for a function. A side-effenting [sic] lexical closure is emphatically not a function.
最佳答案
闭包只是“自由变量”的定义,以及为这些自由变量提供绑定(bind)的外部环境。在 x + 1
x
是一个自由变量;没有定义x
是,所以你只能说这个表达式在包含 x
的环境中具有什么值。 .在 y => x + y
x
仍然是免费的,但 y
不是;表达式定义了一个函数,函数的参数是 y
的绑定(bind)。 .
Scala 上下文中的“词法闭包”基本上只是一个“闭包”(因为它的所有闭包都是词法的),但从技术上讲,“闭包”是一个更一般的概念。 “关闭”本身并没有说明环境从何而来; “词法闭包”指定闭包定义的词法范围(即它在源代码中出现的位置)决定了环境。
所以“副作用的词汇闭包”只是其中之一,它有副作用。
我对此评论的看法是,Apocalisp 将函数的数学思想与要执行的参数化代码块的编程思想进行了对比。不管他是不是这么想的,我都会扩展我的想法:
在数学中,函数基本上只是从某些输入集(函数的 域 )中的值到某些输出集(其 共域 )中的值的映射。在这种观点下,函数不是我们不允许副作用的特殊受限程序形式,“具有副作用”的概念不适用于它。问一个数学函数是否有副作用就像问黄色是否有副作用;甚至“不”的答案也不是真的正确。你对数学函数所能做的就是询问它的 codomain 中的哪个值对应于它的 domain 中的给定值;如果我有 { 1 -> 11, 2 -> 22, 3 -> 33 }
描述的功能我问什么codomain值对应于2,回答“22,对象foo的count
属性现在是7”是没有意义的。
在理想化的函数式编程中,我们仅将代码视为定义与我们要定义的函数相对应的映射的一种方式。最有趣的函数是无限的(或者至少是不切实际的庞大),所以我们不是通过写出从输入到输出的文字映射来做到这一点,而是通过写下描述输出如何对应于输入的或多或少的抽象规则来做到这一点。当然,在实践中,我们确实会花费大量时间来考虑我们的代码将如何执行,但通常函数式程序员更愿意首先考虑定义。
另一方面,传统命令式编程中所谓的函数与函数的数学概念几乎没有关系。程序员的函数不是从域中的值到共域中的值的映射,而是一个接一个地执行的一系列步骤(可能由输入值参数化并返回输出值)。这些步骤中的每一个都可能产生影响,因此您不能忽略它们的存在并说这只是定义域-> 共域映射的另一种方式,并且不能独立于它们的上下文将它们作为事物单独检查。
在想要同时支持函数式编程和命令式编程的编程语言中,您使用相同的语言元素来定义数学函数和程序员的函数。或者,如果您专门使用术语函数来指代数学函数,那么您使用相同的语言元素来定义函数和“其他不是函数的东西”。我用 Apolalisp 的短语“词法闭包”来描述 Scala 的函数定义语法除了函数概念之外的定义,当你进一步补充说它是一个“副作用词法闭包”时,它绝对不是你在说的函数关于。
关于function - "Side-effecting lexical closure"vs Scala 中的函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22288329/
我正在阅读有关 C# 和闭包的各种信息 articles ,Jon Skeet 的精彩“C# in Depth”,我看到像“C# 和 ruby 实现词法闭包”这样的陈述。 为什么作者要包含“词汇”
我有两个编辑器实例。一个是可编辑的第二个只读,用于预览用户输入的内容我在这些编辑器之间复制了编辑器状态 - 没有任何问题但我想当第一个编辑器为空时隐藏第二个编辑器。我正在尝试类似的方法,但它总是返回
我正在使用 Flex 构建自己的语言,但我想知道一些事情: 为什么要使用词法分析器? 他们会帮我做点什么吗? 他们是强制性的吗? 最佳答案 词法分析有助于简化解析,因为词位可以被视为抽象实体而不是具体
考虑到一个二进制数据(视频/图像/音频/可执行文件)可以看作是一长串随机字节, 当数据采用特殊格式(SQL、数据库中的 BOLB、MP3、JSON、XML 等)时,解析器如何知道特殊字符(或字符序列,
我对 javascript 中的 this 有疑问。 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operato
我使用术语“词法编码”是因为我没有更好的编码。 与字母相反,单词可以说是交流的基本单位。 Unicode 尝试为所有已知字母表的每个字母分配一个数值。对一种语言来说是字母,对另一种语言来说是字形。 U
我一直在用 Java 编写一个语音识别程序,只是为了看看它是如何工作的。直到一天前一切都工作得很好。我不知道发生了什么,因为我没有更改代码中的任何内容。 由于出现词汇错误,我想我只需要粘贴我的语法文件
在调试一些较旧的 perl 代码时,我使用 perl critic 来发现错误。我经常偶然发现这个“循环迭代器不是词法”策略: Perl::Critic::Policy::Variables::Req
在 perdoc Socket页,他们使用全局文件句柄作为套接字。 但是如果我在子进程调用的子例程中创建一个套接字,使用词法文件句柄仍然使用 Socket 是否更好? 像这样: use strict;
我正在尝试为我出于个人原因而设计的 C/C++/C#/Java/D 之类的编程语言编写扫描仪。对于这个任务,我使用 Ragel 来生成我的扫描仪。我无法准确理解许多操作符何时触发 Action ,可能
我是 AI 学生,我们使用 JavaCC。 我是新手。我正在尝试简单的例子,但我有一些错误。 1)我从它的网站下载了 JavaCC 0.6 2)我把它解压到C盘 3)我将此代码写在扩展名为“.jj”的
在@lexical/react中,在没有依赖数组的useEffect中注册编辑器命令是否会带来重大损失(性能或其他)? useEffect(() => { const unsubscribe =
我有一个词法编辑器,需要将其序列化为 html,以便我可以将其嵌入到电子邮件模板中。 使用 $generateHtmlFromNodes 函数时,我不断遇到以下错误: Error: Unable to
在经典的编译器理论中,前两个阶段是词法分析和语法分析。他们正在筹备中。词法分析将标记识别为解析的输入。 但是我遇到了一些在词法分析中很难被正确识别的情况。例如下面关于C++模板的代码: map> >>
let textBytes = ctypes.uint8_t("hello"); let a = new SECItem; a.type = siBuffer; a.data = textBytes.
我有4条规则 rule1: match variable rule2: match Float rule3: match Integer rule4: [ \t] ; //skipping space
如果您查看 original Wordnet search并选择“显示选项:显示词汇文件信息”,您将看到一个非常有用的单词分类,称为 词汇文件 .例如,对于“填充”,我们有: S: (n) fi
我已经多次看到术语“词法变量”,主要是在闭包的上下文中。 Paul Graham 在他关于 Lisp 的书中使用这个术语来指代使用 let 表达式定义的变量。 我知道词法作用域是静态作用域的另一个名称
应用程序版本 Elasticsearch:v.7.1 Laravel:v5.8 操作系统版本:Ubuntu 18(服务器)/ Windows 10(开发PC) Elasticsearch搜索API的“
我想以 myObj 作为其运行范围来调用 myObj.sayHello。我了解绑定(bind),它工作得很好。 var myObj = {"name1":"BP", "sayHell
我是一名优秀的程序员,十分优秀!