Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What's the difference between using an informal protocol on NSObject or an protocol with optional methods?

I'm studying some basics about informal protocols and real protocols. What confuses me is, that Cocoa seems to use a lot of informal protocols on NSObject. Those informal protocols are categories on NSObject which declare methods, but do not actually implement them.

As far as I get it right, the only reason they make use of informal protocols (in other words, categories on NSObject that don't provide method implementations), is to give an autocompletion-hint in Xcode.

One example is the -awakeFromNib method defined in NSNibLoading.h, which is an informal protocol on NSObject. The nib loading system checks at runtime if an object implements that method. If it does, then it calls it.

But now let's imagine there was no feature called informal protocol. The alternative that would have the exact same effect would have been a real @protocol declaration which declares an optional method -awakeFromNib. NSObject would just adopt that protocol and the compiler would happily provide autocompletion.

Can anyone point out the big difference between these two strategies? I don't see the point of informal protocols but would really like to do so.

like image 601
Proud Member Avatar asked Jan 14 '11 10:01

Proud Member


People also ask

What is informal protocol?

An informal protocol is a category on NSObject , which implicitly makes almost all objects adopters of the protocol. (A category is a language feature that enables you to add methods to a class without subclassing it.) Implementation of the methods in an informal protocol is optional.

What is a NSObject protocol?

This protocol is imported into Swift with the name NSObjectProtocol . An object that conforms to this protocol can be considered a first-class object. Such an object can be asked about its: Class, and the place of its class in the inheritance hierarchy.

Is protocol formal or informal?

In medicine, a protocol is a formal plan for treating a patient, especially in a specific circumstance. In computing, protocol refers to a set of rules for formatting messages.

What is the use of NSObject?

Locates and returns the address of the receiver's implementation of a method so it can be called as a function.


2 Answers

Two huge differences:

  1. Compile time type checking. An explicit protocol with optional methods is much more clear about what methods you could implement. Both for explicitly adorning the class with the protocol it conforms too, and Xcode can provide much more precise code-completion lists of what you could implement.

  2. It keeps NSObject uncluttered. With the old style informal protocols all methods that are optional instead usually had their default implementation added to NSObject.

The informal protocols where a neat solution to a problem that no longer exist since the introduction of optional methods in protocols in Objective-C 2.0.

like image 93
PeyloW Avatar answered Oct 06 '22 21:10

PeyloW


The big difference is that the @optional keyword was only introduced a few years ago. For new code, informal protocols are basically obsolete. Much of the frameworks is non-new code.

like image 28
Jens Ayton Avatar answered Oct 06 '22 23:10

Jens Ayton