- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
有一个模式我发现自己经常使用,所以我想把它晒干。我有这样的东西:
class InfoGatherer
def foo
true
end
def people
unless @people
@people = # Long and complex calculation (using foo)
end
@people
end
end
我想把它弄干成这样:
class InfoGatherer
extend AttrCalculator
def foo
true
end
attr_calculator(:people) { # Long and complex calculation (using foo) }
end
为此,我定义了一个模块 AttrCalculator
以扩展到 InfoGatherer
。这是我尝试过的:
module AttrCalculator
def attr_calculator(variable_name_symbol)
variable_name = "@#{variable_name_symbol}"
define_method variable_name_symbol do
unless instance_variable_defined?(variable_name)
instance_variable_set(variable_name, block.call)
end
instance_variable_get(variable_name)
end
end
end
不幸的是,当我尝试像 InfoGatherer.new.people
这样简单的东西时,我得到:
NameError: undefined local variable or method `foo' for InfoGatherer:Class
嗯,这很奇怪。为什么 block
在 InfoGatherer:Class
的范围内运行,而不是它的实例 InfoGatherer.new
?
我知道我不能使用 yield
,因为那样会 try catch 错误的 block ,如 here 所示.我尝试使用 self.instance_exec(block)
代替上面的 block.call
,但随后我收到了一个新错误:
LocalJumpError: no block given
嗯?我在 this SO question 中看到同样的错误,但我已经在使用括号表示法,因此那里的答案似乎并不适用。
我也尝试过使用 class_eval
,但我不确定如何在字符串中调用 block
。这当然行不通:
class_eval("
def #{variable_name_symbol}
unless #{variable_name}
#{variable_name} = #{block.call}
end
#{variable_name}
end
")
最佳答案
该用例称为内存。它可以像这样轻松完成:
def people
@people ||= # Long and complex calculation (using foo)
end
你不应该像现在这样陷入困境。
关于ruby - 将 block 传递给 define_method,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27872482/
谁能详细说明ruby的Object#define_method和Module#define_method之间的区别以及它们通常用在什么地方? 最佳答案 对象#define_method 不存在: o
Ruby 中的元编程很棒,因为我经常使用它来模拟基于原型(prototype)的编程,并快速编写一些问题的原型(prototype)解决方案来测试它们的可行性。所以我想知道下面这段代码是否有本质区别:
我必须通过以下测试: def test_can_find_by_arbitrary_fields assert @library.respond_to? :find_by_artist ass
在下面的代码中,模块被扩展,这意味着方法 hash_initialized 被视为类方法,或 eigen 类的实例方法。这是我们需要的,因为 hash_initialized 是在本征类的上下文中调用
我是 ruby 的新手,但我有很多重复的方法。在尝试 DRY 我的代码时,我想到了如下内容: class Foobar def some_method # end def so
所以我正在尝试这段代码, class Colors def initialize color color.each {|c| color c} end def color c
我有很多方法完全相同,但需要为每个方法定义一个特定的名称。因此,我在调用每个单独的 format_ 方法的方法中尝试了以下操作: ['street', 'postcode', 'email', 'ty
define_method 表现出以下行为: class TestClass def exec_block(&block) ; yield ; end end TestClass.new.send
我正在阅读 Ruby 中的元编程。 这是书中的两个代码片段: my_var = "Success" MyClass = Class.new do puts "#{my_var} in the cl
我遇到了以下代码: class MethodLogger def log_method((klass,method_name) klass.class_eval do
我想定义一个接受关键字参数的方法。我希望它在未提供关键字参数时引发,我可以自己编写代码 - 但理想情况下我想让 Ruby 为我做这件事。此外,我希望能够使用 Method#parameters 检查新
有没有办法在YardDoc 中注释用define_method 定义的方法? ? 我试过这个: %w(one two three).each do |type| # The #{type} way
我想将参数传递给使用 define_method 定义的方法,我该怎么做? 最佳答案 传递给 define_method 的 block 可以包含一些参数。这就是您定义的方法接受参数的方式。当你定义一
我想为 Python 类动态定义一些方法。我用谷歌搜索了一会儿,找到了 this .我稍微更改了代码以满足我的要求。 这是我的代码: class Base(object): def add_met
三天来我一直在反对这个问题。我创建了一个模拟 html 页面的类,并告诉 cucumber 步骤定义在哪里填充表单数据: class FlightSearchPage def initialize
所以,我有点想做一些类似于 rspec/mocha 的 mock 的事情。 ,但仅适用于两个对象,而不是所有对象。这是我目前所拥有的: def mock(obj, method_to_mock, va
我在 ruby 中有这段代码: class Package def initialize(name) @name = name @elements = [] end [:type,
当我在 instance_eval block 中为类定义一个方法时,它会创建一个很好的类方法。 例如) class A end A.instance_eval do def method; en
class Temp1 def add(s) match = 'test' self.class.class_eval do define_method(s) do
这就是我想要做的。 # DSL Commands command :foo, :name, :age command :bar, :name # Defines methods def foo(nam
我是一名优秀的程序员,十分优秀!