- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在阅读 Haskell 相关的东西时,我有时会遇到“打结”这个表达,我想我理解它的作用,但不理解它的作用。
那么,对于这个概念有什么好的、基本的、简单易懂的解释吗?
最佳答案
打结是循环数据结构问题的解决方案。在命令式语言中,您可以通过首先创建一个非循环结构来构建循环结构,然后返回并修复指针以添加循环性。
假设您想要一个包含元素“0”和“1”的二元素循环列表。这似乎是不可能构造的,因为如果您创建“1”节点,然后创建“0”节点来指向它,那么您就无法返回并修复“1”节点以指向“0”节点。因此,您遇到了先有鸡还是先有蛋的情况,两个节点都需要先存在才能创建。
以下是在 Haskell 中的操作方法。考虑以下值:
alternates = x where
x = 0 : y
y = 1 : x
在非惰性语言中,由于未终止的递归,这将是一个无限循环。但在 Haskell 中,惰性求值做了正确的事情:它生成一个二元素循环列表。
要了解它在实践中如何工作,请考虑运行时会发生什么。惰性求值的通常“thunk”实现将未求值的表达式表示为包含函数指针以及要传递给函数的参数的数据结构。计算此值时,thunk 会被实际值替换,以便将来的引用不必再次调用该函数。
当您获取列表的第一个元素时,“x”将被计算为值(0,&y),其中“&y”位是指向“y”值的指针。由于 'y' 尚未被评估,这目前是一个 thunk。当您获取列表的第二个元素时,计算机会跟踪从 x 到该 thunk 的链接并对其进行评估。它的计算结果为 (1, &x),或者换句话说,是一个返回原始“x”值的指针。现在内存中有一个循环列表。程序员不需要修复后向指针,因为惰性求值机制会为您完成此操作。
关于haskell - “tying the knot”的解释,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/357956/
假设我有一个自定义类型(我可以扩展): struct Foo { int a; string b; }; 如何使该对象的实例可分配给 std::tie ,即 std::tuple引用文
我在 SQL Server 中寻找类似的东西: SELECT TOP n WITH TIES FROM tablename 我知道 PostgreSQL 中的 LIMIT,但是否存在与上述等效的内容?
我的脚本似乎有一个小问题,我需要对脚本中较早的子例程调用“tied”,以便我可以访问与哈希绑定(bind)的对象相关的函数到。问题是,当我运行脚本时,它返回错误“无法在 cbc_encrypt_tes
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
论文网址: https://dl.acm.org/doi/10.1145/3404835.3462961 。 Arxiv: https://arxiv.org/abs/2104.08419
这是我试图解决 weekly 的挑战 #2 . 挑战很模糊,所以我决定尝试用内存来实现一个标量值。我对容器应该如何工作的理解可能有缺陷,但我真正不明白的是,为什么 say self.VAR.WHAT是
在阅读 Haskell 相关的东西时,我有时会遇到“打结”这个表达,我想我理解它的作用,但不理解它的作用。 那么,对于这个概念有什么好的、基本的、简单易懂的解释吗? 最佳答案 打结是循环数据结构问题的
如何保留哈希元素的添加顺序对于第二个VAR? (哈希值的哈希值) 例如: use Tie::IxHash; my %hash; tie %hash, "Tie::IxHash"; for my $nu
我打算编写一个简单的文本查看器,我希望它能够处理非常大的文件。我正在考虑使用 Tie::File为此,并对行进行分页。这是懒惰地加载行,还是一次加载所有行? 最佳答案 它不会加载整个文件。来自 doc
我有一个 [String: Int] 类型的字典,它的值为 let dic = [“a”:4, “b”:3, “c”:3] 我想按值和使用方法对字典进行排序 dic = dic.sorted(by:
当一个函数需要返回两个参数时,你可以使用 std::pair 编写它: std::pair f() {return std::make_pair(1,2);} 如果你想使用它,你可以这样写: int
在 c++11 中,std::tie 是否允许隐式转换? 以下代码编译并运行,但我不确定幕后到底发生了什么,或者这是否安全。 std::tuple foo() { return std::make_t
std::tie 返回一个引用元组,因此您可以执行以下操作: int foo, bar, baz; std::tie(foo, bar, baz) = std::make_tuple(1, 2, 3)
我目前正在开发一款问答游戏。我写了一个 Team 类,一个 Question 类和一个 Round 类。 这是我的团队类(我不会发布属性、构造函数和方法,因为它们与我的问题无关)。 public cl
我正在阅读 a bit about tuples . 现在我不清楚以下语法: std::tie (myint, std::ignore, mychar) = mytuple; 理解它的作用并不难,但是
是否有与 Perl 等效的 Ruby Tie::File模块? 最佳答案 没有。 读取文件并将行作为 Array 返回很容易,就像在 Perl 中一样: array = File.readlines(
我使用 std::tie 并没有考虑太多。它有效,所以我刚刚接受了这一点: auto test() { int a, b; std::tie(a, b) = std::make_tuple
tying-the-knot 策略可用于构建图,例如,使用简单的两条边图作为示例: data Node = Node Node Node -- a - b -- | | -- c - d squa
#!/usr/bin/perl use strict; use warnings; use Tie::File; use Data::Dumper; use Benchmark; my $t0 = B
我写了一个花哨的“zip 迭代器”,它已经完成了许多角色(可以用于 for_each、复制循环、容器迭代器范围构造函数等......)。 在处理所涉及的对/元组的所有模板代码下,归结为迭代器的解引用运
我是一名优秀的程序员,十分优秀!