OC 消息轉(zhuǎn)發(fā)機(jī)制,當(dāng)調(diào)用一個 NSObject 對象不存在的方法時(shí)癣丧,并不會馬上拋出異常铣墨,而是會經(jīng)過多層轉(zhuǎn)發(fā)浦夷,層層調(diào)用對象的-resolveInstanceMethod:, -forwardingTargetForSelector:, -methodSignatureForSelector:, -forwardInvocation: 等方法邑飒,其中最后-forwardInvocation: 是會有一個 NSInvocation對象金刁,這個NSInvocation對象保存了這個方法調(diào)用的所有信息帅涂,包括 Selector 名,參數(shù)和返回值類型尤蛮,最重要的是有所有參數(shù)值媳友,可以從這個NSInvocation 對象里拿到調(diào)用的所有參數(shù)值。我們可以想辦法讓每個需要被 JS 替換的方法調(diào)用最后都調(diào)到-forwardInvocation:产捞,就可以解決無法拿到參數(shù)值的問題了庆锦。
也就是說熱更新、熱修復(fù)就是利用OC的消息機(jī)制消息發(fā)送轧葛,動態(tài)解析,消息轉(zhuǎn)發(fā)艇搀。就是在消息轉(zhuǎn)發(fā)階段動態(tài)的添加了方法的實(shí)現(xiàn)尿扯,以達(dá)到熱修復(fù)的目的。
JSPatch是一個開源項(xiàng)目(JSPatch)焰雕,JSPatch 把 OC 手動翻譯成 JS衷笋,在運(yùn)行時(shí)通過 OC 的動態(tài)特性去調(diào)用和替換 OC 方法,實(shí)時(shí)修復(fù) bug矩屁。修 bug 這個需求基本是滿足了辟宗,雖然小繞了下道,但成本還是很低的吝秕,引擎本身也很小很輕量泊脐,接入對 APP 不會有任何負(fù)面影響,在關(guān)鍵時(shí)刻又可以幫大忙烁峭,成本低收益高容客,于是很容易推廣開秕铛。JSPatch 滿足了修 bug 的需求,但還是無法滿足動態(tài)化的全部需求缩挑,最大的缺點(diǎn)在于需要手寫 JS但两,雖然已經(jīng)有轉(zhuǎn)換器輔助,但還沒做到100%準(zhǔn)確供置,用來修 bug 還好谨湘,用來添加功能的話學(xué)習(xí)成本和開發(fā)效率還不夠。
于是有了滴滴的 DynamicCocoa 這種方案芥丧,繞了一個更大的道紧阔,從編譯階段入手,通過 clang 把 OC 代碼編譯成自己定制的 JS 格式娄柳,再動態(tài)下發(fā)去執(zhí)行寓辱,做到原生開發(fā),動態(tài)運(yùn)行赤拒,主打動態(tài)添加功能秫筏,當(dāng)然順便把修 bug 也給支持了。手機(jī) QQ 內(nèi)部也有一個類似的方案挎挖,不過更進(jìn)一步这敬,他們通過 clang 把 OC 代碼編譯成自己定制的字節(jié)碼動態(tài)下發(fā),然后開發(fā)一個虛擬機(jī)去執(zhí)行(驚呆了)蕉朵,同樣實(shí)現(xiàn)了原生開發(fā)崔涂,動態(tài)運(yùn)行,都是 NB 得很的方案始衅。只要底層處理做得足夠好冷蚂,也是個成本低收益高的方案,不過目前都還沒開源汛闸,還沒能看到實(shí)際效果和 NB 的源碼蝙茶,挺期待。
以下文章可以做一個學(xué)習(xí)參考:
GCD面試要點(diǎn)
block面試要點(diǎn)
Runtime面試要點(diǎn)
RunLoop面試要點(diǎn)
內(nèi)存管理面試要點(diǎn)
MVC诸老、MVVM面試要點(diǎn)
網(wǎng)絡(luò)性能優(yōu)化面試要點(diǎn)
網(wǎng)絡(luò)編程面試要點(diǎn)
KVC&KVO面試要點(diǎn)
數(shù)據(jù)存儲面試要點(diǎn)
混編技術(shù)面試要點(diǎn)
設(shè)計(jì)模式面試要點(diǎn)
UI面試要點(diǎn)