在ipad上build自己app的時候,出現如下提示:
objc[1334]: Class ASIAuthenticationDialog is implemented in both /var/mobile/Applications/DDD5C5F0-49E4-425F-AEAE-0AC27FA8A0AC/MyApp.app/MyApp and /Library/MobileSubstrate/DynamicLibraries/SogouInputIPad.dylib. One of the two will be used. Which one is undefined.
提示說明自己的app中和搜狗的輸入法同時都使用了ASIAuthenticationDialog,導致objc-runtime無法決定到底調用那個程序中的實現。
查找資料發現原因:objc runtime 對所用app使用同一個命名空間(flat namespace),運行機制如下:
首先二進制映像被加載,檢查程序依賴關系
每一個二進制映像被加載的同時,程序的objc classes在objc runtime命名空間中注冊
如果具有相同名稱的類被再次加載,objc runtime的行為是不可預知的。一種可能的情況是任意一個程序的該類會被加載(這應該也是默認動作)
因為自己的app和搜狗輸入法都使用了ASIHTTPRequest這個第三方封裝,所以才引出了這個警告。
對於我們無法獲得沖突apps的源代碼的情況下,相應的解決方法我所找到的是將同一個類進行重命名,但是這樣做還是比較繁瑣的。
搜索到的相關的解決方法主要是針對 ios unit test時的解決方法,對於不同app的解決方法只有將自己的類進行重命名。
資料裡面提到的 Bundle Loader、Symbols hidden by default ,可以在TARGET的 Build Settings 裡面進行搜索即可找到。
綜上,編寫app盡量使用 Cocoa touch 自帶的類來實現,少用第三方的封裝。