Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

object_setClass to bigger class

I am changing the class of some objects using object_setClass(id object, Class cls). I am changing the class to a subclass of the original class. Then I set some properties that are only defined on the subclass, and things seem to work fine.

I was a bit surprised that this worked, because object_setClass, as far as I understand, doesn't reallocate the object, it only changes the isa pointer. If the subclass instances are considerably larger (meaning having many more ivars) than the original class instances, I don't see how the object can work as expected.

Does this work only because there is a lot of buffer memory between objects in memory (due to alignment etc)?

Is this robust, or could it crash under some circumstances?

like image 232
Felixyz Avatar asked Jul 27 '10 17:07

Felixyz


2 Answers

It could crash. As can be seen in the source code of the runtime here, it really just swaps the isa pointer.

If you really want to swap the isa to an isa of a subclass with more ivars, you should use class_createInstance with nonzero extraBytes.

like image 119
Yuji Avatar answered Oct 02 '22 14:10

Yuji


Instead of using a larger subclass, use objc_setAssociatedObject and objc_getAssociatedObject to attach dynamically additional objects to your existing fixed-size object.

like image 28
Léo Natan Avatar answered Oct 02 '22 15:10

Léo Natan