iOS面試題:為什么CTMediator方案優(yōu)于基于Router的方案据块?

Router的缺點(diǎn):

  • 在組件化的實(shí)施過程中码邻,注冊(cè)URL并不是充分必要條件。組件是不需要向組件管理器注冊(cè)URL的另假,注冊(cè)了URL之后像屋,會(huì)造成不必要的內(nèi)存常駐。注冊(cè)URL的目的其實(shí)是一個(gè)服務(wù)發(fā)現(xiàn)的過程边篮,在iOS領(lǐng)域中己莺,服務(wù)發(fā)現(xiàn)的方式是不需要通過主動(dòng)注冊(cè)的,使用runtime就可以了戈轿。另外凌受,注冊(cè)部分的代碼的維護(hù)是一個(gè)相對(duì)麻煩的事情,每一次支持新調(diào)用時(shí)思杯,都要去維護(hù)一次注冊(cè)列表胜蛉。如果有調(diào)用被棄用了挠进,是經(jīng)常會(huì)忘記刪項(xiàng)目的。runtime由于不存在注冊(cè)過程誊册,那就也不會(huì)產(chǎn)生維護(hù)的操作领突,維護(hù)成本就降低了。 由于通過runtime做到了服務(wù)的自動(dòng)發(fā)現(xiàn)案怯,拓展調(diào)用接口的任務(wù)就僅在于各自的模塊君旦,任何一次新接口添加,新業(yè)務(wù)添加嘲碱,都不必去主工程做操作金砍,十分透明。

  • 在iOS領(lǐng)域里麦锯,一定是組件化的中間件為openURL提供服務(wù)恕稠,而不是openURL方式為組件化提供服務(wù)。如果在給App實(shí)施組件化方案的過程中是基于openURL的方案的話离咐,有一個(gè)致命缺陷:非常規(guī)對(duì)象(不能被字符串化到URL中的對(duì)象谱俭,例如UIImage)無法參與本地組件間調(diào)度。

  • 在本地調(diào)用中使用URL的方式其實(shí)是不必要的宵蛀,如果業(yè)務(wù)工程師在本地間調(diào)度時(shí)需要給出URL昆著,那么就不可避免要提供params,在調(diào)用時(shí)要提供哪些params是業(yè)務(wù)工程師很容易懵逼的地方术陶。

  • 為了支持傳遞非常規(guī)參數(shù)凑懂,蘑菇街的方案采用了protocol,這個(gè)會(huì)侵入業(yè)務(wù)梧宫。由于業(yè)務(wù)中的某個(gè)對(duì)象需要被調(diào)用接谨,因此必須要符合某個(gè)可被調(diào)用的protocol,然而這個(gè)protocol又不存在于當(dāng)前業(yè)務(wù)領(lǐng)域塘匣,于是當(dāng)前業(yè)務(wù)就不得不依賴public Protocol脓豪。這對(duì)于將來的業(yè)務(wù)遷移是有非常大的影響的。

CTMediator的優(yōu)點(diǎn):

  • 調(diào)用時(shí)忌卤,區(qū)分了本地應(yīng)用調(diào)用和遠(yuǎn)程應(yīng)用調(diào)用扫夜。本地應(yīng)用調(diào)用為遠(yuǎn)程應(yīng)用調(diào)用提供服務(wù)。

  • 組件僅通過Action暴露可調(diào)用接口驰徊,模塊與模塊之間的接口被固化在了Target-Action這一層笤闯,避免了實(shí)施組件化的改造過程中,對(duì)Business的侵入棍厂,同時(shí)也提高了組件化接口的可維護(hù)性颗味。

  • 方便傳遞各種類型的參數(shù)。


更多:iOS面試題合集

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末牺弹,一起剝皮案震驚了整個(gè)濱河市浦马,隨后出現(xiàn)的幾起案子时呀,更是在濱河造成了極大的恐慌,老刑警劉巖捐韩,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件退唠,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡荤胁,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門屎债,熙熙樓的掌柜王于貴愁眉苦臉地迎上來仅政,“玉大人,你說我怎么就攤上這事盆驹≡驳ぃ” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵躯喇,是天一觀的道長辫封。 經(jīng)常有香客問我,道長廉丽,這世上最難降的妖魔是什么倦微? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮正压,結(jié)果婚禮上欣福,老公的妹妹穿的比我還像新娘。我一直安慰自己焦履,他們只是感情好拓劝,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著嘉裤,像睡著了一般郑临。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上屑宠,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天厢洞,我揣著相機(jī)與錄音,去河邊找鬼侨把。 笑死犀变,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的秋柄。 我是一名探鬼主播获枝,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼骇笔!你這毒婦竟也來了省店?” 一聲冷哼從身側(cè)響起嚣崭,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎懦傍,沒想到半個(gè)月后雹舀,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡粗俱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年说榆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寸认。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡签财,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出偏塞,到底是詐尸還是另有隱情唱蒸,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布灸叼,位于F島的核電站神汹,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏古今。R本人自食惡果不足惜屁魏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望沧卢。 院中可真熱鬧蚁堤,春花似錦、人聲如沸但狭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽立磁。三九已至呈队,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間唱歧,已是汗流浹背宪摧。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留颅崩,地道東北人浙巫。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓戈钢,卻偏偏與公主長得像益老,于是被迫代替她去往敵國和親镊尺。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容