在利用OC开发应用程序中,须要大量创建对象,那么它的过程是什么呢?
比方:NSArray *array = [[NSArrayalloc] init];
在说明之前,先把OC的Class描写叙述一下:
Class
Objective-C类是由Class类型来表示的,它实际上是一个指向objc_class结构体的指针。它的定义例如以下:
typedef struct objc_class *Class;
查看objc/runtime.h中objc_class结构体的定义例如以下:
struct objc_class {
Class isa;
#if !__OBJC2__
Class super_class OBJC2_UNAVAILABLE; // 父类
const char *name OBJC2_UNAVAILABLE; // 类名
long version OBJC2_UNAVAILABLE; // 类的版本号信息。默觉得0
long info OBJC2_UNAVAILABLE; // 类信息,供执行期使用的一些位标识
long instance_size OBJC2_UNAVAILABLE; // 该类的实例变量大小
struct objc_ivar_list *ivars OBJC2_UNAVAILABLE; // 该类的成员变量链表
struct objc_method_list **methodLists OBJC2_UNAVAILABLE; // 方法定义的链表
struct objc_cache *cache OBJC2_UNAVAILABLE; // 方法缓存
struct objc_protocol_list *protocols OBJC2_UNAVAILABLE; // 协议链表
#endif
} OBJC2_UNAVAILABLE;
说明:
- isa:须要注意的是在Objective-C中。全部的类自身也是一个对象。这个对象的Class里面也有一个isa指针,它指向metaClass(元类),我们会在后面介绍它。
- super_class:指向该类的父类。假设该类已经是最顶层的根类(如NSObject或NSProxy),则super_class为NULL。
-
cache:用于缓存近期使用的方法。一个接收者对象接收到一个消息时。它会依据isa指针去查找可以响应这个消息的对象。在实际使用中,这个对象仅仅有一部分方法是经常使用的,非常多方法事实上非常少用或者根本用不上。这样的情况下,假设每次消息来时,我们都是methodLists中遍历一遍,性能势必非常差。这时。cache就派上用场了。
在我们每次调用过一个方法后。这种方法就会被缓存到cache列表中,下次调用的时候runtime就会优先去cache中查找。假设cache没有,才去methodLists中查找方法。这样,对于那些经经常使用到的方法的调用,但提高了调用的效率。
- version:我们能够使用这个字段来提供类的版本号信息。这对于对象的序列化很实用,它但是让我们识别出不同类定义版本号中实例变量布局的改变。
以下以array对象为例来说明其运行过程:
-
[NSArray alloc]先被运行。
由于NSArray没有+alloc方法,于是去父类NSObject去查找。
- 检測NSObject是否响应+alloc方法,发现响应。于是检測NSArray类,并依据其所需的内存空间大小開始分配内存空间,然后把isa指针指向NSArray类。同一时候,+alloc也被加进cache方法列表里面。
- 接着。运行-init方法,假设NSArray响应该方法。则直接将其增加cache方法列表。假设不响应,则去父类查找。
- 在后期的操作中,假设再以[[NSArray alloc] init]这样的方式来创建数组,则会直接从cache方法列表中取出对应的方法,直接调用。