Objective-C respondsToSelector

前端 未结 4 1207
难免孤独
难免孤独 2020-12-04 06:07

From what I have learned so far: In Objective-C you can send any message to any object. If the object does implement the right method it will be executed otherwise nothing w

相关标签:
4条回答
  • 2020-12-04 06:11

    First of all, the name of a method (its selector) includes all subparts and colon characters, as mvds said.

    Second of all, the method -respondsToSelector: is not called by the runtime, it's usually called by the user (yourself or APIs that want to know if a delegate, for example, responds to an optional method of the protocol).

    When you send a message to an object, the runtime will look for the implementation of the method in the class of the object (through the object's isa pointer). It's equivalent to sending -respondsToSelector: although the message itself is not dispatched. If the implementation of the method is found in the class or in its superclasses, it's called with all the arguments you passed in.

    If not, then the runtime gives the message a second chance to be executed. It will start by sending the message + (BOOL)resolveInstanceMethod:(SEL)name to the class of the object: this method allows you to add the method at runtime to the class: if this message returns YES, it means it can redispatch the message.

    If not it gives the message a third chance to be executed, it sends - (id)forwardingTargetForSelector:(SEL)aSelector with the selector, this method can return another object that may be able to respond to the selector on behalf of the actual receiver, if the returned object can respond, the method is executed and the value is returned as if it was returned by the original message. (Note: This is available beginning with OS X 10.6 or iOS 4.)

    If the returned object is nil or self (to avoid infinite loops), the runtime gives the message a fourth chance to execute the method… It sends the message - (NSMethodSignature *)methodSignatureForSelector:(SEL)aSelector to get a method signature in order to build an invocation. If one is provided then an invocation is sent through the message - (void)forwardInvocation:(NSInvocation *)anInvocation. In this method you can parse the invocation and build other messages to send to other targets in any ways you want, and then you can set the return value of the invocation… That value will act as the return value of the original message.

    Finally, if no method signature is returned by the object, then the runtime sends the message - (void)doesNotRecognizeSelector:(SEL)aSelector to your object, the implementation of this method in NSObject class throws an exception.

    0 讨论(0)
  • 2020-12-04 06:18

    There is an +instancesRespondToSelector: method. As the name suggests, it tells you whether the instances of the class implement that method.

    0 讨论(0)
  • 2020-12-04 06:24

    For one thing, the selector is not only the "name" of the message, but also what follows, i.e. the arguments, and their names.

    So the correct selector for some -(void)setAlternateTitle:(NSString*)str would be

    @selector(setAlternateTitle:)
    

    with the :

    As for your problem: If a class respondsToSelector() and you perform that selector, you shouldn't get a crash on sending an unknown selector. What kind of crash log do you see in the debugging window?

    (ps. why not include the [slider setAlternateTitle:...] in the if ( responds ) { ... } conditional block?)

    0 讨论(0)
  • 2020-12-04 06:35

    "This is because before the message is sent Objective-C will perform respondsToSelector."

    I guess this is not correct. If the object does not respond to selector, it will crash at runtime. There is no automatic checking by the system. If there was a check by the run time system then we should never get "unrecognized selector sent to instance" exception.

    Please make me correct if I am wrong.

    EDIT: This is not a straight forward crash, but the default result is the process will be terminated. The whole sequence is already explained in comment and other answer, so I am not going to write that again.

    0 讨论(0)
提交回复
热议问题