一个类的初始化写法纠结了多少人!
下面这种初始化方法在Object C里,就像耶稣一样无法撼动其位置,也像耶稣一样,没人敢有异议,以至于有人会说记住就可以了,别问为什么。
对于初次接触Object C的人来说,这种写法甚是纠结,
但是如果你要是知道,Object C里会出现一下几种匪夷所思的现象,你就会感慨,原来还真想耶稣一样能保护你。
1.实例的内存地址,是在alloc的时候就已经准备好了的,init只是用来初始化其内部数据。
2.调用父类初始化方法时,有可能会改变实例的内存地址!
3.调用父类初始化方法时,有可能会返回nil!
为了对应情况2,需要把父类初始化方法改变后的地址传给self,要不然子类初始化方法所处理的数据还都在老地址上。
为了对应情况3,需要判断返回的父类是不是nil,如果是nil的话,子类也无法处理了。
出现情况3,应该是父类初始化出错了。
但是什么时候会出现情况2,以及出现情况2时,老内存的占用是如何释放的,还是不得其所。
下面这种初始化方法在Object C里,就像耶稣一样无法撼动其位置,也像耶稣一样,没人敢有异议,以至于有人会说记住就可以了,别问为什么。
- (id) init
{
if (self = [super init])
{
// your code here
}
return self;
}
对于初次接触Object C的人来说,这种写法甚是纠结,
但是如果你要是知道,Object C里会出现一下几种匪夷所思的现象,你就会感慨,原来还真想耶稣一样能保护你。
1.实例的内存地址,是在alloc的时候就已经准备好了的,init只是用来初始化其内部数据。
2.调用父类初始化方法时,有可能会改变实例的内存地址!
3.调用父类初始化方法时,有可能会返回nil!
为了对应情况2,需要把父类初始化方法改变后的地址传给self,要不然子类初始化方法所处理的数据还都在老地址上。
为了对应情况3,需要判断返回的父类是不是nil,如果是nil的话,子类也无法处理了。
出现情况3,应该是父类初始化出错了。
但是什么时候会出现情况2,以及出现情况2时,老内存的占用是如何释放的,还是不得其所。