背景:由于公司需求淀衣,需要把公司各部門做到互聯(lián)互通灯帮,于是作為支付部門的我們便被推到了風(fēng)口浪尖之上,需要把我們的收銀臺sdk嵌入其他部門的app中擎椰;除了給自己公司部門支子,還為別的公司提供了支付這提服務(wù)。
編寫:sdk的編寫一般都是以一個單例 manger 來提供服務(wù)接口达舒,然后不同的功能設(shè)置不同的類值朋,以組合關(guān)系的模式互相調(diào)用完成交互叹侄。如下圖:
典型的例子可以參考afnetworking。上圖是涉及到架構(gòu)層面的昨登,架構(gòu)的能力需要考慮到應(yīng)用場景趾代,以及擁有豐富的經(jīng)驗才能設(shè)計的妥當(dāng)。我也只是班門弄斧了丰辣,多閱讀源碼撒强,體會那些成熟框架,從大到分析它的架構(gòu)糯俗,細(xì)到分析一次調(diào)用的數(shù)據(jù)流向尿褪,數(shù)據(jù)就像是血液,流經(jīng)每一個節(jié)點得湘,每一個節(jié)點或是對其進(jìn)行封裝杖玲,或是對其的處理進(jìn)行回調(diào)。前輩們的代碼有些穩(wěn)扎穩(wěn)打淘正,有些也卻是點睛之筆摆马。站在巨人的肩膀上成長,才會成長的更快鸿吆。
sdk應(yīng)該注意的點:
1 . 千萬注意類命名囤采,作為sdk首要保證的是不要與人家的庫有類名沖突,每次看到 duplicate ?class 這個就頭疼惩淳,因為我們的sdk代碼是從app里扒出來的蕉毯,這也是沒辦法的事,畢竟沒給那時間去重新寫思犁,sdk還是提供UI界面的代虾,在這第三方橫行的iOS 應(yīng)用中,重復(fù)的概率太高了激蹲。所以記得要給引用的第三方類庫加個用不會沖突的前綴棉磨。
2.? 類沖突 還是算小事,畢竟導(dǎo)入app中編譯都過不去学辱,最怕的是 分類(category)乘瓤,iOS分類是個語言特性,在編譯的時候分類中的方法是要被編譯到類的方法列表中的策泣。想起惡心的來了衙傀。。着降。? marsory 這個庫是很多寫UI的人都要用的差油,其中可以通過兩個宏 來控制屬性和方法簡寫.mas_top ----->.top,剛好還是UIView的分類里任洞,sdk里剛好有一個 UIView的分類蓄喇,為了方便fram的設(shè)置,也加入了top bottom ?width 等屬性交掏,然后就出現(xiàn)了方法沖突妆偏。當(dāng)app調(diào)用top的時候,會從UIView的方法列中查找該方法盅弛,調(diào)用查到的第一個實現(xiàn)钱骂。
3.當(dāng)涉及到UI界面的sdk的時候,像是導(dǎo)航欄字體 ?按鈕風(fēng)格 (顏色挪鹏,圓角)這些都要去從plis中讀取會不較好见秽,因為這樣 第三方調(diào)用就可以根據(jù)自己app的風(fēng)格去配置。
4. 還有第三方的使用讨盒。解取。。這絕對是所有寫sdk人最愁的問題返顺,像網(wǎng)絡(luò)請求 json處理等幾乎都像是約定好了的都是 AFNetworking JSONKit禀苦。人家app里幾乎都會用到,所以 sdk最好是在這里的每個類之前加一個前綴遂鹊,所以 sdk最好是在這里的每個類之前加一個前綴振乏,所以 sdk最好是在這里的每個類之前加一個前綴,這將是一個浩大的工程秉扑。慧邮。。舟陆。這也是由于objective-c語言特性決定的误澳,沒有命名空間這一說法。
還有一個 最后的辦法吨娜,但是也不推薦脓匿,畢竟sdk不是只為一家而做。在上一篇文章最后有提到宦赠。陪毡。傳送門