Before I switched to iOS development via Monotouch I played around a bit with ObjectiveC. Ever since one thing has been on my mind “Key Value Coding” (KVC). I have never understood what it is good for and what the magic behind it is.
For my understanding it is just a collections of names and values, like .NET’s NameValueCollection: Instead of setting anObject.Address = "An address Value" you would write anObject.Properties["Address"] = "An address value".
Great. So what? Because this appears to be too easy to me I’m sure that can’t be it.
Or is it because .NET has reflection and therefore has no need for something like Key-Value-Coding? I can grab the type of “anObject” and use reflection to loop all of its properties and look for the one called “Address” and then use reflection to set the value.
Is that maybe the analogy of KVC?
I’m hoping there is somebody out there who’s a pro in ObjC and C#/.NET who can explain to me what the benefits are and how it would translate into .NET.
Please don’t just point me to Apple’s documentation. I know all that. I’m trying to find out if something has been missing in my coding-life so far by not knowing KVC? Or have I maybe been using something similar in .NET not being aware that it would translate into KVC if I was using ObjC?
From somebody who uses both every day for probably 3 years now:
As you figured out, there’s nothing amazingly complex in KVC that can’t be done with dictionaries and NameValueCollections in C#.
The big difference is that KVC is built in the language. An object in Obj-C IS a NameValueCollection. You don’t have to change the way you develop (from classes and properties to dictionaries) to use it. You can create your object with the properties you want, and then later on call a valueForKey:@”name”, and everything still works.
Now you can say: “yeah cool, but I can do that with reflection!”. Sure you can, but just as before, you’ll have to change the way you develop again, not counting the fact that reflection is a lot slower in general.
Another cool feature of KVC it it allows you to use KVO, which basically allows you to register to receive notifications about changes in any object without having to write a single line of code in those objects. So, in any object in your application, you can call “addObserver:forKeyPath:”, and receive a callback if anybody else in your application changes that property. This is really useful for live apps, like iOS apps.
Again, you can implement KVO in C# (MVVM frameworks for example do this all the time), but you have to write extra code for that. In Obj-C, it’s built in the language.