關於Xcode上的Other linker flags

問題

在ios開發過程中,有時候會用到第三方的靜態庫(.a文件),然後導入後發現編譯正常但經常有運行時會出現多種類型的錯誤,從而導致程序閃退。


可能的解決方案

解決上述問題的一種極有可能的解決方案是修改工程Build Settings選項卡Linking命令組中Other linker flags,如圖所示。

wKiom1bcsurC2NKfAAS5kHSUHKs986.jpg

Linking命令組中Other linker flags

Other Linker Flags里加的參數主要有如下三個:

  • -ObjC

  • -all_load

  • -force_load

下面來說說每個參數存在的意義和具體做的事情。

首先是-ObjC,一般這個參數足夠解決前面提到的問題,蘋果官方說明如下:

This flag causes the linker to load every object file in the library that defines an Objective-C class or category. While this option will typically result in a larger executable (due to additional object code loaded into the application), it will allow the successful creation of effective Objective-C static libraries that contain categories on existing classes.

簡單說來,加了這個參數後,鏈接器就會把靜態庫中所有的Objective-C類和分類都加載到最後的可執行文件中,雖然這樣可能會因爲加載了很多不必要的文件而導致可執行文件變大,但是這個參數很好地解決了我們所遇到的問題。但是事實真的是這樣的嗎?

如果-ObjC參數真的這麼有效,那麼事情就會簡單多了。

Important: For 64-bit and iPhone OS applications, there is a linker bug that prevents -ObjC from loading objects files from static libraries that contain only categories and no classes. The workaround is to use the -allload or -forceload flags.

當靜態庫中只有分類而沒有類的時候,-ObjC參數就會失效了。這時候,就需要使用-all_load或者-force_load了。

-all_load會讓鏈接器把所有找到的目標文件都加載到可執行文件中,但是千萬不要隨便使用這個參數!假如你使用了不止一個靜態庫文件,然後又使用了這個參數,那麼你很有可能會遇到ld: duplicate symbol錯誤,因爲不同的庫文件裏面可能會有相同的目標文件,所以建議在遇到-ObjC失效的情況下使用-force_load參數。

-force_load所做的事情跟-all_load其實是一樣的,但是-force_load需要指定要進行全部加載的庫文件的路徑,這樣的話,你就只是完全加載了一個庫文件,不影響其餘庫文件的按需加載。

參考:

1.http://www.cnblogs.com/robinkey/archive/2013/05/27/3101095.html

2.http://my.oschina.net/ffs/blog/372850

3.http://my.oschina.net/u/728866/blog/194741


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章