Mam klasę:
class TestClass
def method1
end
def method2
end
def method3
end
end
Jak mogę uzyskać listę moich metod w tej klasie ( method1
, method2
, method3
)?
Mam klasę:
class TestClass
def method1
end
def method2
end
def method3
end
end
Jak mogę uzyskać listę moich metod w tej klasie ( method1
, method2
, method3
)?
Odpowiedzi:
Właściwie chcesz TestClass.instance_methods
, chyba że jesteś zainteresowany tym TestClass
, co samo może zrobić.
class TestClass
def method1
end
def method2
end
def method3
end
end
TestClass.methods.grep(/method1/) # => []
TestClass.instance_methods.grep(/method1/) # => ["method1"]
TestClass.methods.grep(/new/) # => ["new"]
Lub możesz zadzwonić methods
(nie instance_methods
) na obiekt:
test_object = TestClass.new
test_object.methods.grep(/method1/) # => ["method1"]
print TestClass.new.instance_methods
, pojawia się ten błądmy_class.rb:10:in <main>: undefined method instance_methods for #<TestClass:0x96b9d20> (NoMethodError)
TestClass.new.methods
. Może „to” było w mojej odpowiedzi niejednoznaczne.
[:method1]
zamiast tego dostałbyś.
TestClass.methods(false)
aby uzyskać tylko metody należące tylko do tej klasy.
TestClass.instance_methods(false)
zwróci metody z podanego przykładu (ponieważ są one metodami instancji TestClass).
TestClass.instance_methods
lub bez wszystkich odziedziczonych metod
TestClass.instance_methods - Object.methods
(Było „TestClass.methods - Object.methods”)
TestClass.methods(false)
.
TestClass.methods(false)
powraca pusty
method1
, method2
lub method3
, ponieważ są to metody wystąpień klasy, a nie metody TestClass
samego obiektu.
Możesz uzyskać bardziej szczegółową listę (np . Uporządkowaną przez zdefiniowanie klasy) z klejnotami, takimi jak debugowanie lub looksee .
$ irb --simple-prompt
class TestClass
def method1
end
def method2
end
def method3
end
end
tc_list = TestClass.instance_methods(false)
#[:method1, :method2, :method3]
puts tc_list
#method1
#method2
#method3
Według Ruby Doc instance_methods
Zwraca tablicę zawierającą nazwy publicznych i chronionych metod wystąpienia w odbiorniku. W przypadku modułu są to metody publiczne i chronione; dla klasy są to metody instancji (nie pojedyncze). Jeśli opcjonalny parametr ma wartość false, metody wszystkich przodków nie są uwzględniane. Biorę przykład oficjalnej dokumentacji.
module A
def method1()
puts "method1 say hi"
end
end
class B
include A #mixin
def method2()
puts "method2 say hi"
end
end
class C < B #inheritance
def method3()
puts "method3 say hi"
end
end
Zobaczmy wynik.
A.instance_methods(false)
=> [:method1]
A.instance_methods
=> [:method1]
B.instance_methods
=> [:method2, :method1, :nil?, :===, ...# ] # methods inherited from parent class, most important :method1 is also visible because we mix module A in class B
B.instance_methods(false)
=> [:method2]
C.instance_methods
=> [:method3, :method2, :method1, :nil?, :===, ...#] # same as above
C.instance_methods(false)
=> [:method3]
Aby uzyskać tylko własne metody i wykluczyć odziedziczone:
Z poziomu instancji:
self.methods - self.class.superclass.instance_methods
Z zewnątrz:
TestClass.instance_methods - TestClass.superclass.instance_methods
Dodaj to do zajęć:
class TestClass
class << self
def own_methods
self.instance_methods - self.superclass.instance_methods
end
end
end
TestClass.own_methods
=> [:method1, :method2, method3]
(z rubinem 2.6.x)