今天碰到一個(gè)問題,就是用到懶加載的時(shí)候,我用了self,結(jié)果報(bào)錯(cuò)直接蹦了,
我們老師說這是self遞歸引用了,可我還是不明白它們之間的區(qū)別
人生最曼妙的風(fēng)景,竟是內(nèi)心的淡定與從容!
self.x 是訪問屬性, 實(shí)際上是去訪問 getX 或者 setX 方法,但是大部分時(shí)候,編譯器幫你自動實(shí)現(xiàn)了這倆方法, 并自動建立了一個(gè)關(guān)聯(lián)的實(shí)例變量, 所以你感覺不到。 _x 就是那個(gè)自動創(chuàng)建的實(shí)例變量。
比如說你定義了下面這個(gè)屬性:
@property(nonation, strong) NSString *x;
有一堆隱藏的(簡化)代碼如下:
NSString *_x;
-(NSString *)x {
return _x;
}
-(void)setX:(NSString *)x {
_x = x;
}
我猜你的懶加載代碼就重載了屬性的 get 方法,self.x 其實(shí)就是去調(diào)用 [self x] 方法, 如果你在這個(gè) get 方法里使用 self.x, 那這個(gè) self.x 又去調(diào)用, [self x] 方法,這就是個(gè)無限遞歸了。
如果引用的話不會有區(qū)別,是同一個(gè)指針,如果賦值是有區(qū)別的 self.xx=oo 首先把xxretaincount -1然后retain oo _XX復(fù)制直接指向oo 不存在retain這一步步。也不會
我只是猜測你可能是:
self.some = [self some];
-(type)some{
self.some = [...];
}
然后你在調(diào)用self.some時(shí)候 等于使用了[self some],some里面的self.some再次調(diào)用了[self some]。。。形成了一個(gè)loop。。。
下劃線 就是直接訪問,越過了set get這些。。