Instance Method

removeObserver:

Removes all entries specifying an observer from the notification center's dispatch table.

Declaration

- (void)removeObserver:(id)observer;

Parameters

observer

The observer to remove from the dispatch table. Specify an observer to remove only entries for this observer.

Discussion

Removing the observer stops it from receiving notifications.

If you used addObserverForName:object:queue:usingBlock: to create your observer, you should call this method or removeObserver:name:object: before the system deallocates any object that addObserverForName:object:queue:usingBlock: specifies.

If your app targets iOS 9.0 and later or macOS 10.11 and later, and you used addObserver:selector:name:object:, you do not need to unregister the observer. If you forget or are unable to remove the observer, the system cleans up the next time it would have posted to it.

When removing an observer, remove it with the most specific detail possible. For example, if you used a name and object to register the observer, use removeObserver:name:object: with the name and object.

The following example illustrates how to unregister someObserver for all previously registered notifications. This is safe to do in the dealloc method, but you shouldn’t use it otherwise (use removeObserver:name:object: instead).

[[NSNotificationCenter defaultCenter] removeObserver:someObserver];

See Also

Adding and Removing Notification Observers

- addObserverForName:object:queue:usingBlock:

Adds an entry to the notification center to receive notifications that passed to the provided block.

- addObserver:selector:name:object:

Adds an entry to the notification center to call the provided selector with the notification.

- removeObserver:name:object:

Removes matching entries from the notification center's dispatch table.