如何解决更改类和模块中的子定义样式后未初始化的常量错误
require 'concurrent_rails/adapters/future'
module ConcurrentRails
class Promises
include ConcurrentRails::Adapters::Future
这是模块
module ConcurrentRails::Adapters
module Future
extend ActiveSupport::Concern
class_methods do
....
这很好用,但我试图将类和模块的定义保留在一行中:
module ConcurrentRails::Adapters::Future
extend ActiveSupport::Concern
class_methods do
...
当我像上面那样更改定义时,没有触及 promises.rb
文件,我收到此错误:
future.rb:3:in `<top (required)>': uninitialized constant ConcurrentRails::Adapters (NameError)
我之前在 require
定义上尝试过 concurrent_rails.rb
文件,但没有任何效果。
如果有帮助,here 是来源
解决方法
作为一般规则,我建议不要使用嵌套的类/模块定义。当然,它可以节省一行代码/缩进,但您会遇到此类问题。
例如,参见this rubocop
rule:
类:RuboCop::Cop::Style::ClassAndModuleChildren
概述
这个警察在课堂上检查孩子定义的风格,然后 模块。基本上有两种不同的风格:
只有一个孩子的类/模块才强制使用紧凑样式。
示例:
-
EnforcedStyle:嵌套(默认)
# good # have each child on its own line class Foo class Bar end end
-
强制风格:紧凑
# good # combine definitions as much as possible class Foo::Bar end
定义嵌套模块是有问题的,因为它只有在父模块已经定义的情况下才能在ruby中工作。例如:
irb(main):001:1* module Foo::Bar
irb(main):002:0> end
Traceback (most recent call last):
1: from (irb):1
NameError (uninitialized constant Foo)
虽然这工作正常:
irb(main):001:1* module Foo
irb(main):002:2* module Bar
irb(main):003:1* end
irb(main):004:0> end
另外,即使已经定义了父模块,您仍然可能会遇到other issues with module nesting in ruby。
所以,简而言之:module ConcurrentRails::Adapters::Future
不起作用,因为 ConcurrentRails::Adapters
尚未定义。
您可以通过首先明确定义“父模块”来解决这个问题,但是,无论如何,我都不建议使用 3+ 层嵌套模块定义。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。