将父类指针赋给self的原因理解:
在ObjC中的init方法中经常看到如下一段代码
if(self=[super init]){
}
这段代码是首先初始化父类,然后再把父类的指针赋给self。
要想明白这段代码的意图,首先要明白self是什么。
self其实是一个指向该类的继承链中的第一个类的第一个实例变量的指针。
初始化父类,意味着父类的self指向了父类的继承链中的第一个类的第一个实例变量。
而在父类的初始化中会初始化父类的父类。
依次调用后,self就指向了继承链中的第一个类的第一个实例变量。
super的init方法,有时候会返回其他的类的实例,比如说,NSArray的init有时会返回的是NSCFArray.
而NSArray和NSCFArray可能有不同的继承链(NSCFArray好像是C实现的),
那子类的self究竟是指向这两个继承链中的哪个链的第一个类的第一个实例变量呢?
肯定是实际返回的这个NSCFArray的继承链。所以需要将真正的继承链的指针赋给self,
以便这个继承链中第一个类的各个实例变量到最后一个类的各个实例变量都能被映射到正确的内存位置。
这样才能确保初始化的第一步是正确的。
赋值测试和检查非0值结合是一种典型的C风格用法,只要父类初始化没有异常,并且返回的不是nil,该代码就会向下执行。
在ObjC中的init方法中经常看到如下一段代码
if(self=[super init]){
}
这段代码是首先初始化父类,然后再把父类的指针赋给self。
要想明白这段代码的意图,首先要明白self是什么。
self其实是一个指向该类的继承链中的第一个类的第一个实例变量的指针。
初始化父类,意味着父类的self指向了父类的继承链中的第一个类的第一个实例变量。
而在父类的初始化中会初始化父类的父类。
依次调用后,self就指向了继承链中的第一个类的第一个实例变量。
super的init方法,有时候会返回其他的类的实例,比如说,NSArray的init有时会返回的是NSCFArray.
而NSArray和NSCFArray可能有不同的继承链(NSCFArray好像是C实现的),
那子类的self究竟是指向这两个继承链中的哪个链的第一个类的第一个实例变量呢?
肯定是实际返回的这个NSCFArray的继承链。所以需要将真正的继承链的指针赋给self,
以便这个继承链中第一个类的各个实例变量到最后一个类的各个实例变量都能被映射到正确的内存位置。
这样才能确保初始化的第一步是正确的。
赋值测试和检查非0值结合是一种典型的C风格用法,只要父类初始化没有异常,并且返回的不是nil,该代码就会向下执行。