Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6321143
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 24, 20262026-05-24T16:05:56+00:00 2026-05-24T16:05:56+00:00

I just read a couple of tutorials regarding KVO, but I have not yet

  • 0

I just read a couple of tutorials regarding KVO, but I have not yet discovered the reason of its existence. Isn’t NSNotificationCenter an easier way to observe objects?

I am new to Stackoverflow, so just tell me if there is something wrong in the way I am asking this question!

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-24T16:05:56+00:00Added an answer on May 24, 2026 at 4:05 pm

    Notifications and KVO serve similar functions, but with different trade-offs.

    • Notifications are easy to understand. KVO is… challenging… to understand (at least to understand how to use it well).

    • Notifications require modification to the observed code. The observed must explicitly generate every notification it offers. KVO is transparent to the observed code as long as the observed code conforms to KVC (which it should anyway).

    • Notifications have overhead even if you don’t use them. Every time the observed code posts a notification, it must be checked against every observation in the system, even if no one is observing that object (even if no one is observing anything). This can be very non-trivial if there are more than a few hundred observations in the system. It can be a serious problem if there are a few thousand. KVO has zero overhead for any object that is not actually observed.

    In general, I discourage KVO because of some specific implementation problems that I believe make it hard to use correctly. It’s difficult to observe an object that your superclass also observes without special knowledge of your superclass. Its heavy reliance of string literals make small typos hard to catch at compile time. In general, I find code that relies heavily on it becomes complex and hard to read, and begins to pick up spooky-action-at-a-distance bugs. NSNotification code tends to be more straightforward and you can see what’s happening. Random code doesn’t just run when you didn’t expect it.

    All that said, KVO is an important feature and developers need to understand it. More and more low-level objects rely on it because of it’s zero-overhead advantages. But for new developers, I typically recommend that they rely more on notification rather than KVO.

    There is a third way. You can keep a list of listeners, and send them messages when things change, just like delegate methods. Some people call these “multicast delegates” but “listeners” is more correct here because they don’t modify the object’s behavior as a delegate does. Doing it this way can be dramatically faster than NSNotification if you need a lot of observation in a system, without adding the complexity of KVO.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have read a couple of tutorials on several web sites as well as
I've read a couple similar questions regarding this topic on StackOverflow, but none of
I have read a couple of articles but im still having trouble understanding this.
I have read a couple articles but I am still a bit confused. How
I just read in Code Complete that you should not use exceptions for flow
I have a couple of UITableViewController classes and I just noticed that these methods
I have written an attribute before, but I I have not written a validation
I read a couple of thing about this, but I can't figure how to
My app uses a local SQLite database to read data. Just a couple of
Just read a post about MVC best practices . Couple parts of the post

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.