我是鲁比的新手。我对我在这里读到的一些代码感到困惑:
engines/
这是代码:
module Cashier
class Railtie < ::Rails::Railtie
config.cashier = Cashier
initializer "cashier.active_support.cache.instrumentation"
ActiveSupport::Cache::Store.instrument = true
end
end
end这句话在大多数语言中是不允许的,我对此感到惊讶:
config.cashier = Cashier因此,我在模块出纳器的定义中,但是我还可以实例化模块出纳器的一个实例,并在这里使用它?这条线路怎么回事?当我在定义出纳员的代码中时,我如何分配出纳员?在Java中,我认为我从未在类的定义中实例化过一个类。
发布于 2015-04-06 04:33:28
您不是在这里实例化收银员(您不能在Ruby中创建模块实例);您只是在引用Cashier常量,它指的是模块的一个实例,当您到达这一行时已经定义了该实例。
Ruby创建一个空模块实例,并借助module Foo将其分配给Foo常量。模块主体定义可以看作是重新打开空模块并向其添加附加功能。Ruby不需要完整的模块定义才能“完成”模块并将其分配给常量;它是在考虑主体定义之前创建和分配的。
也就是说,守则:
module Foo
puts Foo.object_id
end在功能上相当于:
# Create a new Module instance and assign it to the Foo constant
Foo = Module.new
# Reopen the Module instance assigned to the constant Foo for modification
module Foo
# Do stuff in here to add functionality to the Foo module
# Since Foo is already defined, we can get its object_id.
puts Foo.object_id
end从编译语言的角度来看,这当然是没有意义的(毕竟,如果您还没有完成Cashier的定义,您怎么知道它是什么呢?),但是Ruby的解释特性意味着它倾向于更宽松地对待模块和类定义,这就是允许这种行为的原因。
https://stackoverflow.com/questions/29463412
复制相似问题