ld: 4773 duplicate symbols for architecture x86_64

起源

最近在項目中集成百度地圖的相關功能,不過遇到了一個問題岭佳。百度地圖中集成了ssl庫libssl.a血巍,而我們工程中的另外一個第三方庫也集成了這個庫。編譯的時候就會造成沖突珊随,顯示ld: 4773 duplicate symbols for architecture x86_64述寡。

解決方式

解決問題的方式大概就分為兩種:

1.修改其中的一個第三方庫文件柿隙。

2.修改OTHER_LDFLAGS的編譯選項,讓編譯器只編譯其中的一個ssl庫鲫凶。

第一種方式禀崖,網(wǎng)上有不少文章說,具體可以參考:

http://www.reibang.com/p/c7274dca62f7

第二種方式螟炫,主要和OTHER_LDFLAGS選項有關波附。

OTHER_LDFLAGS詳解

OTHER_LDFLAGS常用的有三種:

-ObjC

鏈接器會把靜態(tài)庫中所有的Objective-C類和類別都加載到最后的可執(zhí)行文件中。

-all_load

強制鏈接器把所有找到的目標文件都加載到可執(zhí)行文件中昼钻。

-force_load

所做的事情跟-all_load其實是一樣的掸屡,但是-force_load需要指定要進行全部加載的庫文件的路徑。

但是千萬不要隨便使用-all_load和-force_load參數(shù)然评!假如你使用了不止一個靜態(tài)庫文件仅财,然后又使用了這個參數(shù),那么你很有可能會遇到ld: duplicate symbol錯誤碗淌,因為不同的庫文件里面可能會有相同的目標文件盏求。但是在cocoapods創(chuàng)建的工程中,它會自動的設置OTHER_LDFLAGS為-ObjC -all_load 亿眠。

之所以這樣做是因為在xcode4之前碎罚,xcode有個bug,你用了-ObjC以后纳像,如果類庫中只有category沒有這個類的具體實現(xiàn)時候荆烈,這些category是加載不進來。變通方法就是加入-all_load或者-force-load爹耗。-all_load會強制鏈接器把目標文件都加載進來耙考,即使沒有objc代碼。

因此我們可以將工程中的-all_load 直接去掉就行潭兽,但是因為我們是使用cocoapods來管理工程的,為了不需要每次pod install之后都需要刪除這個參數(shù)斗遏,我們需要修改podfile文件山卦。

CocoaPods的解決方法

post_install do |installer|
  installer.pods_project.targets.each do |target|
      #獲取準備修改的pod工程 `Pod-target-lib` 
      if target.name == "Pod-target-lib"
        puts "Updating #{target.name} OTHER_LDFLAGS"
        #獲取工程的xcconfig文件的路徑
        xcconfig_path = ""
        target.build_configurations.each do |config|
          new_xcconfig_path = config.base_configuration_reference.real_path
          puts "new_xcconfig_path #{new_xcconfig_path} OTHER_LDFLAGS"
          if new_xcconfig_path != xcconfig_path
            xcconfig_path = config.base_configuration_reference.real_path

            # 從xcconfig中讀取build_settings到字典中
            build_settings = Hash[*File.read(xcconfig_path).lines.map{|x| x.split(/\s*=\s*/, 2)}.flatten]

            # 刪除 OTHER_LDFLAGS 中的-all_load
            other_flag = build_settings['OTHER_LDFLAGS'];
            build_settings['OTHER_LDFLAGS'] = other_flag.gsub('-all_load',' ')

            # 清除當前文件的內(nèi)容
            File.open(xcconfig_path, "w") {|file| file.puts ""}

            # 將build_settings字典寫回xcconfig
            build_settings.each do |key,value|
              File.open(xcconfig_path, "a") {|file| file.puts "#{key} = #{value}"}
            end
          end
        end
      end
    end
end

這樣,每次pod install后诵次,都會自動尋找當前工程的xcconfig配置文件账蓉,并將其中的OTHER_LDFLAGS中的-all_load選項替換成空格鍵。

其他注意事項

不過需要注意的是逾一,你需要保證這兩個相互沖突的第三方庫所共同引用的庫的版本是相同的铸本,否則可能會出現(xiàn)異常。

如果出現(xiàn)所引用的兩個第三方庫的版本不同遵堵,出現(xiàn)符號沖突時箱玷,動態(tài)鏈接會使用先加載的符號怨规。也就是說在Link Binary With Libraryies中靠前的的動態(tài)庫會優(yōu)先被鏈接,并占據(jù)當前符號的具體實現(xiàn)锡足,后續(xù)的重復類或者方法會自動被忽略波丰。


Xcode中的動態(tài)鏈接庫

參考文獻:

https://www.cnblogs.com/lulushen/p/7646635.html

https://stackoverflow.com/questions/30244675/how-can-i-modify-other-ldflags-via-cocoapods-post-install-hook

https://blog.csdn.net/idoit0204/article/details/51514299

https://www.zhihu.com/question/20728615

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市舶得,隨后出現(xiàn)的幾起案子掰烟,更是在濱河造成了極大的恐慌,老刑警劉巖沐批,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纫骑,死亡現(xiàn)場離奇詭異,居然都是意外死亡九孩,警方通過查閱死者的電腦和手機惧磺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來捻撑,“玉大人磨隘,你說我怎么就攤上這事」嘶迹” “怎么了番捂?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長江解。 經(jīng)常有香客問我设预,道長,這世上最難降的妖魔是什么犁河? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任鳖枕,我火速辦了婚禮,結果婚禮上桨螺,老公的妹妹穿的比我還像新娘宾符。我一直安慰自己,他們只是感情好灭翔,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布魏烫。 她就那樣靜靜地躺著,像睡著了一般肝箱。 火紅的嫁衣襯著肌膚如雪哄褒。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天煌张,我揣著相機與錄音呐赡,去河邊找鬼。 笑死骏融,一個胖子當著我的面吹牛链嘀,可吹牛的內(nèi)容都是我干的萌狂。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼管闷,長吁一口氣:“原來是場噩夢啊……” “哼粥脚!你這毒婦竟也來了?” 一聲冷哼從身側響起包个,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤刷允,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后碧囊,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體树灶,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年糯而,在試婚紗的時候發(fā)現(xiàn)自己被綠了天通。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡熄驼,死狀恐怖像寒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情瓜贾,我是刑警寧澤诺祸,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站祭芦,受9級特大地震影響筷笨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜龟劲,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一胃夏、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧昌跌,春花似錦仰禀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至审胸,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間卸勺,已是汗流浹背砂沛。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留曙求,地道東北人碍庵。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓映企,卻偏偏與公主長得像,于是被迫代替她去往敵國和親静浴。 傳聞我的和親對象是個殘疾皇子堰氓,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354