gpt4 book ai didi

ruby - 当在 Ruby 中需要一个文件时,技术上会发生什么?

转载 作者:数据小太阳 更新时间:2023-10-29 08:44:40 25 4
gpt4 key购买 nike

如果我有一个名为 app.rb 的文件需要另一个名为 foo.rb 的文件,那么 Ruby 在后台做了什么来生成 中定义的常量>foo.rbapp.rb 中变得可用?

摘自 Yukihiro Matsumoto 的“The Ruby Programming Language”:

Files loaded with load or require are executed in a new top-level scope that is different from the one in which load or require was invoked. The loaded file can see all global variables and constants that have been defined at the time it is loaded, but it does not have access to the local scope from which the load was initiated.

我很难想象这一点。


例如:

foo.rb:

class Foo
def hello
puts "Hello, world!"
end
end

app.rb:

require_relative "foo"

foo_obj = Foo.new
foo_obj.hello # => "Hello, world!"

p Object.constants.grep /^Foo/ # => [:Foo]

Ruby 如何将 Foo 常量添加到 Object 类中?

最佳答案

嗯,非常直接,它在当前 $LOAD_PATH 的所有目录中查找作为参数给定的路径 require。如果它在 $LOAD_PATH 的基本路径之一中找到具有该部分路径的文件,则会加载它。它还将其标记为已加载——require 永远不会加载同一个文件两次,如果你第二次需要同一个文件基本上是空操作。

关于本地范围,它非常简单:

 foo = "x"
require 'some_file'

那里需要的 some_file(无论是使用 require 还是 load 加载)都无法访问局部变量“foo”。它不是就好像代码是在加载/需要时粘贴的。相反,它被加载到它自己的局部范围内,不与加载/需要它的上下文共享局部变量。

同样,在 require 之后,在所需的 some_file 中设置的局部变量在外部也不可见。同样,它就好像代码是在那个时候粘贴的。代码已加载,但它在加载/需要时不与上下文共享任何局部变量访问。

您可能预料到了,也可能没有预料到。就是这样,就是这个意思。

但这只适用于局部变量。在所需的 some_file 之外定义的常量仍然可用;并且在所需的 some_file 中定义的常量在加载后仍可用于其他内容。回想一下,ruby 类实际上是通过常量访问的(SomeClass 是一个常量,它指向实际的类)。所以这就是为什么在 some_file 中定义的常量在被要求或加载后可用于任何其他代码。

除了查看 C 实现(这也超出了我的范围)之外,我不确定如何回答“它做了什么使之成为可能”。它只是...将文件加载到当前的 ruby​​ 环境中。这就是使之成为可能的原因。但是它加载它就好像它在它自己的局部变量范围内一样,这就是它不共享局部变量的原因。

关于ruby - 当在 Ruby 中需要一个文件时,技术上会发生什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33244582/

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