KVO - copying observed object - objective-c

I'd like to be sure about something.
Suppose I have a NSArray, with some objects.
Suppose that those objects are observed.
Now, if I create another NSArray with the first one (initWithArray:copyItems:NO), will the observation be untouched ?
And if I create with copying (initWithArray:copyItems:YES), will the observation follow the new objects in the new array ?
Thanks !

The observation is linked to the original objects by their pointers.
If you create a new array without copying then the objects are the same. The observation doesn't change, you just have multiple references to the same objects.
If you create a new array with copying then the objects are different but the original objects still exist in the original array. The observation doesn't change, you are still observing the original objects. The new objects are effectively unrelated and have no observers.

Related

How to create a sorted NSArray from an NSSet that contains arbitrary objects?

I have an NSSet that contains many different types of objects. Typically it will contain some combination of NSDictionaries, NSStrings, NSArrays, and Classes, i.e. the objective-c "Class" type. I need a way to produce an NSArray containing all of the objects in this NSSet, but is sorted so that it will always be in the same order for any set containing the same objects. To be specific, by "same object" I mean by value, not by address. It doesn't matter how it's sorted, as long as it's consistent.
I haven't found a way to do this so far. I can't find any way of doing an ordered comparison between two arbitrary objects. Does anyone have any suggestions on how to accomplish this?
All objects are derived from NSObject, so you could simply sort by [NSObject description] (reference) which will be a summary of the object contents.
EDIT: As pointed out by #Paul.s in the comment; hash (reference) is the way to go (it will be quicker to compare).

Unique Identifier for NSManagedObject

I have a need to obtain a unique identifier for a type of NSManagedObject I've created. It needs to be available as soon as the object has been created, never change, and be completely unique.
This rules out the NSManagedObjectID, as this can change when the context is saved. I believe the -hash method could be non-unique if my objects have the same properties.
I'd really like to avoid creating an otherwise useless uniqueIdentifier UUID field on the entity as this seems wasteful and messy. Is there an accepted best practice here?
try the URIRepresentation property of NSManagedObjectID. this is very unique ID for the current NSManagerObject but be careful until the NSManagedObject is not saved it gives you a temporary ID only, not a permanent one and they might be different. (I'm just saying it because I don't know for what and how you want to use the unique ID.)
UPDATE #1
this is not an imaginary unique ID only, this is pure unique URL for each individual NSManagedObject (like every file has a unique URL), using them you can find again the original NSManagedObject, after you lost their pointer. I know it is hard to understand, but this is the point of the NSManagedObjectID and its properties.
(if you don't understand how the CoreData and their objects work, you would not downvote the answer. please, read more documentation instead of the pointless downvoting.)
UPDATE #2
according to #NickLocking comment, I would extend the bold part of my answer above:
until saving the NSManagedObjectContext for the the new and still unsaved NSManagedObject classes has a temporary unique ID only. They will get the permanent unique ID after they are saved at first time.
Eventually I have decided that there is no good way to do this, so I just created a uniqueIdentifier field that I apply a UUID to on awakeFromInsert.
Saving the object causes other parts of my application, specifically NSFetchedResultsControllers, to update before I'm finished with the object. I briefly tried NSManagedObjectContext's obtainPermanentObjectIds:withError: method, thinking it would obtain the object IDs without saving the context, but in fact it does simply save the context.
The only unique identifiers provided automatically by CoreData is the object ID, but as you have noted it will change after it is initially created. But before you go coming up with another way to work around this, you might want to consider defining something like the following in your managed object class:
- (NSManagedObjectID *)permID {
if ([[self objectID] isTemporaryID]) {
// Save myself, returning nil if there are errors
}
return [self objectID];
}
This approach isn't perfect by any means, especially if you need to expose the permanent ID before the object is in a state where it is valid and can be saved to the database. But it will allow you to expose a permanent ID in a consistent way as long as you don't need it before the object can be saved.

What happens to duplicate keys when using dictionaryWithObjects:forKeys:?

If I use dictionaryWithObjects:forKeys:, and my array of keys happens to have duplicates, what happens? I presume the last instance of the duplicate key will be the value associated with the key; is that correct?
The docs say:
dictionaryWithObjects:forKeys:
...
This method steps through the objects and keys arrays, creating entries in the new dictionary as it goes.
Since a dictionary can't have multiple entries for the same key, yes, the "steps through" strongly implies that later elements in the initializing arrays will clobber earlier ones.

What is a Dictionary of Arrays in OOP?

In the context of OOP, what is the name (or class name) of a data structure composed of a Dictionary of Arrays?
(a Dictionary where each key is mapped to a collection of values)
In the case you cannot find a class representing this data structure, what would be a proper name for this object?
I came from http://en.wikipedia.org/wiki/List_of_data_structure but the most similar I've found is http://en.wikipedia.org/wiki/Multimap which it seems to me that is wrong because the article talks about cardinality and I don't care about that.
I believe that it is usually just called a Dictionary of Arrays. ;) Usually you don't need a special data structure, you just have a dictionary that has references to Arrays as values.

How to (properly) create unique object IDs for instances of NSManagedObject?

I want to set custom NSManagedObject IDs to match the IDs of their corresponding objects in my CouchDB. The CoreData documentation (in "Using Managed Objects") says:
You can sometimes benefit from creating your own unique ID (UUID) property which can be defined and set for newly inserted objects. This allows you to efficiently locate specific objects using predicates (though before a save operation new objects can be found only in their original context).
But the NSManagedObjectContext documentation says you "absolutely must not override" objectID.
So, how does one properly set a custom object ID?
Reading through the documentation I think it is suggesting that you create an additional property on your object that stores your own UUID (the ID from CouchDB in this case) rather than overriding objectID. You can then use a predicate to search against your own UUID property you created and stored the CouchDB ID in. Note that you must perform a save operation first if you are searching outside of the original context.