jjzjj

metaprogramming

全部标签

Ruby:为每个子类执行代码

给定一个父类,有没有办法在加载时为每个子类插入代码?即。给定:ParentClass,我如何像这样插入代码:classChildClass对于ParentClass的所有子类? 最佳答案 在ParentClass中覆盖继承的方法classParentClassdefself.inherited(subclass)execute_functionsuperend...end参见:http://ruby-doc.org/core-2.0/Class.html#method-i-inherited

Ruby 类 nil 对象

我如何在ruby​​中创建一个在类似于nil的逻辑表达式中被评估为false的对象?我的意图是启用对其他对象的嵌套调用,在这些对象中,链的中间某处的值通常是nil,但允许所有调用继续-返回我的类nil对象而不是nil本身。该对象将返回自身以响应它不知道如何处理的任何收到的消息,我预计我将需要实现一些覆盖方法,例如nil?.例如:fizz.buzz.foo.bar如果buzzfizz的属性(property)不可用我会返回我的类似nil的对象,它会接受一直到bar的调用回归自身。最终,上面的陈述应该评估为false。编辑:根据下面所有很好的答案,我得出以下结论:classNilClass

ruby - 如何在ruby中动态定义实例方法?

我想通过父类的类方法动态创建子类的实例方法。classFoodefself.add_fizz_method&body#???(Thisisline3)endendclassBarnilclassBaradd_fizz_methoddop"iliketurtles"endendBar.new.fizz#=>"iliketurtles"在第3行写什么? 最佳答案 像这样使用define_method:classFoodefself.add_fizz_method&blockdefine_method'fizz',&blockendend

ruby - __callee__ 和 __method__ 之间的区别

在Ruby中,可以使用任何一种__callee__或__method__找到当前正在执行的方法的名称。两者有什么区别? 最佳答案 __method__静态查找名称,它指的是最近的词法封闭方法定义的名称。__callee__动态查找名称,它指的是调用方法的名称。两者都不一定需要对应于最初发送的消息:class[:bar,:bar]foo.baz#=>[:bar,:baz]foo.qux#=>[:bar,:method_missing] 关于ruby-__callee__和__method_

ruby - 定义 "method_called".. 如何制作一个钩子(Hook)方法,每次调用类的任何函数时都会调用该方法?

我想制作一个钩子(Hook)方法,每次调用一个类的任何函数时都会调用它。我试过method_added,但是它只在类定义的时候执行一次,classBasedefself.method_added(name)p"#{name.to_s.capitalize}Method'sbeencalled!!"enddefap"acalled."enddefbp"bcalled."endendt1=Base.newt1.at1.bt1.at1.bOutput:"AMethod'sbeencalled!!""BMethod'sbeencalled!!""acalled.""bcalled.""acal

ruby-on-rails - 在 Rails 模型中动态生成范围

我想动态生成作用域。假设我有以下模型:classProduct我们可以用基于POSSIBLE_SIZES常量的东西替换scope调用吗?我认为我违反了DRY以重复它们。 最佳答案 你可以做classProduct但我个人更喜欢:classProduct 关于ruby-on-rails-在Rails模型中动态生成范围,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/14061595/

ruby - 如何将方法动态定义为私有(private)?

这似乎不起作用:classTestprivatedefine_method:private_methoddo"uh!"endendputsTest.new.private_method 最佳答案 Test.instance_eval{private:private_method}或者,直接运行private:private_method来自Test类。 关于ruby-如何将方法动态定义为私有(private)?,我们在StackOverflow上找到一个类似的问题:

ruby - 是否有可能获得 Ruby 中的所有特征类?

在Ruby中获取所有模块的列表很容易:ObjectSpace.each_object(Module).to_a但是,是否有可能获得所有特征类(也称为单例类或元类)的列表?或者特征类是不可见的?我试过了str="foo"my_metaclass=class我正在尝试获取特征类,因为我想列出脚本中定义的所有方法。我可以查找模块和类定义的所有实例方法,然后查找模块和类(或所有对象,如果我想消耗CPU)的单例方法,但这似乎有点老套。 最佳答案 如果您指的是具有单例方法的对象,这应该可行。eigens=[]ObjectSpace.each_o

ruby - 如何调用在不同上下文中获取 block 的 Proc?

以这个例子为例:proc=Proc.new{|x,y,&block|block.call(x,y,self.instance_method)}它有两个参数,x和y,还有一个block。我想为自己使用不同的值来执行该block。像这样的东西几乎可以工作:some_object.instance_exec("xarg","yarg",&proc)但是,这不允许您传入一个block。这也行不通some_object.instance_exec("xarg","yarg",another_proc,&proc)也没有some_object.instance_exec("xarg","yarg"

Ruby:为什么 puts 会调用 to_ary?

我正在学习Ruby中的元编程,并且正在尝试通过method_missing和define_method定义缺失的方法。我遇到了一些意想不到的行为,想知道是否有人可以解释这一点。这是我的类(class):classXdefmethod_missing(m,*args,&block)puts"method#{m}notfound.Definingit."self.class.send:define_method,mdoputs"hifrommethod#{m}"endputs"definedmethod#{m}"endend现在,这段代码:x=X.newx.some_methodputsx