class_addMethod
1.Sel在 class 中有實(shí)現(xiàn)了就不能成功; Sel在class中沒(méi)有Imp就能添加成功(即使有定義)
2.class單指本類(lèi),和superclass無(wú)關(guān) (即使superClass 實(shí)現(xiàn)了Sel,也可以添加成功)
method_getImplementation
獲取的實(shí)時(shí)的Imp
super (self中的super調(diào)用還是本身齿穗,和super本質(zhì)有關(guān))
struct objc_super { id receiver; Class superClass; };
receiver --> 當(dāng)前類(lèi) (self)
superClass ---> 這個(gè)類(lèi)的父類(lèi)
實(shí)際上只是一個(gè)”編譯器標(biāo)示符”逻谦,它負(fù)責(zé)告訴編譯器浪漠,當(dāng)調(diào)用viewDidLoad方法時(shí)姜胖,去調(diào)用父類(lèi)的方法钦勘,而不是本類(lèi)中的方法。
不是調(diào)用objc_msgSend函數(shù)棋傍,而是調(diào)用objc_msgSendSuper函數(shù)
id objc_msgSendSuper ( struct objc_super *super, SEL op, ... );
特殊情況:
-
[obj performSelector:@select(method)] 和 [obj method] 意思一致救拉,可是調(diào)用本質(zhì)上不一樣。
特別是obj --> super
說(shuō)明:
[super viewDidLoad] 調(diào)用的是superClass的方法瘫拣, 數(shù)據(jù)是Self
[super performSelector:@select(viewDidLoad)] 調(diào)用的是self的方法 (respondsToSelector 也是同效果)所以不要用:
super, respondsToSelector和performSelector 組合亿絮, 會(huì)形成死循環(huán)
- 可能調(diào)用的是 super performSelector ; performSelector 中的方法中調(diào)用的是 subClass類(lèi)的實(shí)現(xiàn)
- 用 self去調(diào)用 super的Sel的Imp (self 提供的數(shù)據(jù))
[super respondsToSelector:@selsector(methodOnlyInSub)]
objc_msgSendSuper(objc_super *super, @selector(respondsToSelector:) ) --> 判斷出super有
--> 可能 objc_msgSend(objc_super.receiver, @selector(respondsToSelector:)) = objc_msgSend(self,@selector(respondsToSelector:)) --> 在 respondsToSelector 方法里麸拄,就成了
objc_msgSend(self, @(methodOnlyInSub)) 在self 類(lèi)方法中找實(shí)現(xiàn)
調(diào)用 objc_msgSendSuper 的方法壶谒,將這個(gè)結(jié)構(gòu)體和 respondsToSelector 的 sel 傳遞過(guò)去克锣。函數(shù)里面在做的事情類(lèi)似這樣:從 objc_super 結(jié)構(gòu)體指向的 superClass 的方法列表開(kāi)始找 respondsToSelector 的 selector耘柱,找到后再以 objc_super->receiver 去調(diào)用這個(gè) selector猎物,可能也會(huì)使用 objc_msgSend 這個(gè)函數(shù),不過(guò)此時(shí)的第一個(gè)參數(shù) theReceiver 就是 objc_super->receiver淮椰,第二個(gè)參數(shù)是從 objc_super->superClass 中找到的 selector