如何在Ruby中动态扩展/修改继承类的所有方法?

如何在Ruby中动态扩展/修改继承类的所有方法?,ruby,Ruby,我有一门课是这样的: class MainClass def self.method_one(String) puts "#{self.class} a" end def self.method_two(String) puts "#{self.class} a" end end 我有一个类继承了MainClass: class NewClass < MainClass #any_mathod should match any method t

我有一门课是这样的:

class MainClass
  def self.method_one(String)
      puts "#{self.class} a"
  end
  def self.method_two(String)
      puts "#{self.class} a"
  end
end
我有一个类继承了
MainClass

class NewClass < MainClass
  #any_mathod should match any method that is called for NewClass call
  def self.any_method(a,b)
     puts "#{self.class} b"
     super(a)
  end
end
它将产生:

#=> NewClass String2
#=> MainClass String1

并在
NewClass
类中处理
String1
参数。附加参数的处理器对于所有方法都是相同的。

也许您想要
super
方法

class A
  def self.method_one(a)
    puts "a is #{a}"
  end
end

class B < A
  (superclass.methods - superclass.superclass.methods).each do |m|
    define_singleton_method(m) do |a, b|
      puts "b is #{b}"
      super(a)
    end
  end
end

B.method_one(5, 10)

# => b is 10
# => a is 5
A类
定义自我方法(a)
把“a是{a}”
结束
结束
B类b是10
#=>a是5
试试这个:

class MainClass
    def self.method_one(string)
        puts string
    end
    def self.method_two(string)
        puts string
    end
end


class NewClass < MainClass
    #Iterate through all methods specific to MainClass and redefine
    (self.superclass.public_methods - Object.public_methods).each do |method|
        define_singleton_method method do |string1, string2|
            #Common processing for String1
            puts string1 

            #Call the MainClass method to process String2
            super(string2)
        end
    end
end
class类main类
定义自我方法(字符串)
放线
结束
定义自身方法二(字符串)
放线
结束
结束
类NewClass

NewClass将遍历MainClass中专门定义的所有方法。然后,它将为处理String1的NewClass定义一个类方法,然后调用MainClass方法来处理String2。

另一种方法是放弃继承,改用模块:

module TestModule
  def awesome1
  end
  def awesome2
  end
end

class TestClass
  def self.include mod
    puts (mod.instance_methods - Module.methods).sort
    super
  end
  include TestModule
end

在覆盖的#include中添加单例方法,如上面的答案所示。

是的,但是不在“B”类中定义一个方法,是否可以以某种方式这样做?
module TestModule
  def awesome1
  end
  def awesome2
  end
end

class TestClass
  def self.include mod
    puts (mod.instance_methods - Module.methods).sort
    super
  end
  include TestModule
end