답변:
왜 모든 사람들이 당신이 사용해야하는지 instance_methods
그리고 include?
언제 method_defined?
일 을해야하는지 모르겠습니다 .
class Test
def hello; end
end
Test.method_defined? :hello #=> true
노트
다른 OO 언어에서 Ruby로 온 경우 또는 method_defined
명시 적으로 정의한 메소드 만 의미 한다고 생각합니다 .
def my_method
end
그런 다음 이것을 읽으십시오 :
루비에서는 모델의 속성 (속성)이 기본적으로 방법입니다. 따라서 메서드뿐만 아니라method_defined?
속성에 대해서도 true를 반환합니다 .
예를 들면 다음과 같습니다.
String 속성을 가진 클래스의 인스턴스가 주어지면 first_name
:
<instance>.first_name.class #=> String
<instance>.class.method_defined?(:first_name) #=> true
왜냐하면 first_name
속성과 메소드 (그리고 문자열 유형의 문자열) 이기 때문 입니다.
String.instance_methods(false).include? :freeze
의 잘못된 인수 여부를 정확히 알 수 있습니다 freeze
방법은 String 클래스에 정의되지 않았거나. 이 경우 freeze
메서드는 String에 의해 커널 모듈에서 상속 되므로 false를 반환 하지만 String.method_defined? :freeze
항상 true를 반환하므로 이러한 목적으로 많은 도움이되지 않습니다.
method_defined?
클래스 (예를 들어 사용해야합니다 Array
(예를 들면),하지만 당신은 경우에 그것을 사용하려고 []
)
method_defined?
다음과 같이 사용할 수 있습니다 .
String.method_defined? :upcase # => true
instance_methods.include?
다른 사람들이 제안하는 것 보다 훨씬 쉽고 휴대 가능하며 효율적 입니다.
클래스 method_missing
가 (예를 들어 재정의를 통해 respond_to?
) 또는 Ruby 1.9.2를 정의하여 정의 하여 일부 호출에 동적으로 응답하는지 알 수 없습니다 respond_to_missing?
.
instance.class.method_defined? :upcase
실제로 이것은 객체와 클래스 모두에서 작동하지 않습니다.
이것은 :
class TestClass
def methodName
end
end
주어진 대답을 사용하면 다음과 같이 작동합니다.
TestClass.method_defined? :methodName # => TRUE
그러나 이것은 작동하지 않습니다.
t = TestClass.new
t.method_defined? : methodName # => ERROR!
그래서 나는 이것을 클래스와 객체 모두에 사용합니다 :
클래스:
TestClass.methods.include? 'methodName' # => TRUE
사물:
t = TestClass.new
t.methods.include? 'methodName' # => TRUE
" 클래스가 주어지면 인스턴스에 메소드 (Ruby)가 있는지 확인하십시오 "에 대한 대답 이 더 낫습니다. 분명히 Ruby에는이 기능이 내장되어 있으며, 어떻게 든 놓쳤습니다. 내 대답은 관계없이 참조 용입니다.
루비 클래스는 방법에 반응 instance_methods
하고 public_instance_methods
. Ruby 1.8에서 첫 번째는 모든 인스턴스 메소드 이름을 문자열 배열로 나열하고 두 번째는이를 공개 메소드로 제한합니다. 두 번째 동작은 respond_to?
기본적으로 공개 메소드로 제한 되기 때문에 가장 원하는 것입니다.
Foo.public_instance_methods.include?('bar')
그러나 Ruby 1.9에서는 이러한 메소드가 기호 배열을 리턴합니다.
Foo.public_instance_methods.include?(:bar)
이 작업을 자주 수행하려는 Module
경우 바로 가기 방법을 포함 하도록 확장 할 수 있습니다 . ( Module
대신에 이것을 할당하는 것이 이상하게 보일 수 있지만 Class
, instance_methods
메소드 가있는 곳이기 때문에 해당 패턴에 따라 유지하는 것이 가장 좋습니다.)
class Module
def instance_respond_to?(method_name)
public_instance_methods.include?(method_name)
end
end
Ruby 1.8과 Ruby 1.9를 모두 지원하려면 문자열과 기호를 모두 검색하는 논리를 추가하기에 편리한 위치입니다.
method_defined?
더 낫다 :)
시험 Foo.instance_methods.include? :bar
method_defined?
Rails에 문제가 있다고 생각 합니다. 일치하지 않거나 무언가가있을 수 있으므로 Rails를 사용하는 경우의 무언가를 사용하는 것이 좋습니다 attribute_method?(attribute)
.
" method_defined? 액티브 클래스에서 인스턴스화 될 때까지 작동하지 않습니다를 테스트하는 것은 "불일치에 대한 질문입니다.
객체가 일련의 메소드에 응답 할 수 있는지 확인하는 경우 다음과 같은 작업을 수행 할 수 있습니다.
methods = [:valid?, :chase, :test]
def has_methods?(something, methods)
methods & something.methods == methods
end
는 methods & something.methods
공통 / 일치하는 요소에서 두 배열을 결합합니다. something.methods는 확인중인 모든 메소드를 포함하며 메소드와 동일합니다. 예를 들면 다음과 같습니다.
[1,2] & [1,2,3,4,5]
==> [1,2]
그래서
[1,2] & [1,2,3,4,5] == [1,2]
==> true
이 상황에서 .methods를 호출하면 기호 배열이 반환되고을 사용한 경우 ["my", "methods"]
false를 반환하기 때문에 기호를 사용하려고합니다 .
class Foo
def self.fclass_method
end
def finstance_method
end
end
foo_obj = Foo.new
foo_obj.class.methods(false)
=> [:fclass_method]
foo_obj.class.instance_methods(false)
=> [:fclass_method]
이것이 당신에게 도움이되기를 바랍니다!