gpt4 book ai didi

ruby-on-rails - 为什么 class_eval 以不同的方式评估字符串和 block ?

转载 作者:行者123 更新时间:2023-12-04 12:55:34 31 4
gpt4 key购买 nike

我是 ruby​​ 的新手,今天我发现了 class_eval 的一些不同行为用于字符串和块。例如

class A
end

class C
A.class_eval("print Module.nesting") # [A, C]
A.class_eval{print Module.nesting} # [C]
end
正如您在字符串 Module.nesting 的情况下所见打印 [A,C],而在块的情况下,它只打印 C。
你能告诉我这是什么原因吗?

最佳答案

在第一种情况下,您将一个字符串填充到 class_eval 中。 ,并且这个 class_eval 是在类 A 上调用的。因此,当计算表达式时,Module.nesting - 需要产生嵌套层级 - 发现自己在 A 中,依次在 C 内进行评估.
在第二种情况下,您传递一个块,它类似于 proc 对象。效果堪比

 class C
p = Proc.new { print Module.nesting }
do_something(p)
end
Proc 代表一个闭包,即上下文是创建 Proc 的上下文。很明显,这里的嵌套只是 C,如果你在 do_something 中计算 p,这不会改变。 .
这是一件好事。想象一下以下情况:
def f(p)
x = 'f'
p.call
end

def g
x = 'g'
p = Proc.new { puts x }
f(p)
end
因为 p 的绑定(bind)发生在方法 g 内部,所以块中引用的 x 指的是本地值 xg ,虽然 f有一个同名的局部变量。因此,g 在这里打印。以同样的方式,在您的示例中重现了块定义点的嵌套。

关于ruby-on-rails - 为什么 class_eval 以不同的方式评估字符串和 block ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68058552/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com