青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

gcc 庫順序問題解決方法

Posted on 2008-11-09 12:18 小蘇 閱讀(11068) 評論(3)  編輯 收藏 引用
    使用gcc生成可執行文件時,大部分時候我們需要連接我們自己打包(AR)好的一些庫文件,對于中大型(50萬代碼行以上)項目上,你將面對數個項目組,最好的情況是每個項目組發布自己的打包.ar文件,這些.ar文件之間沒有任何依賴關系, 然后由持續集成(ci)小組對這些包進行連接,不幸的是,這幾乎是不可能的, 我們在連接時還是遇到了liba.ar和libb.ar相互依賴的情況。

因為gcc的庫是個有點怪怪的特性,在看-l幫助時可以看到:
       -l library
           Search the library named library when linking.  (The second alter-
           native with the library as a separate argument is only for POSIX
           compliance and is not recommended.)

           It makes a difference where in the command you write this option;
           the linker searches and processes libraries and object files in the
           order they are specified.  Thus, foo.o -lz bar.o searches library z
           after file foo.o but before bar.o.  If bar.o refers to functions in
           z, those functions may not be loaded.

    出于知識產權保護的考慮,每一個項目組可能只允許看到自己的代碼和別的項目組的頭文件,這給CI小組帶來了很頭痛的事情,很多時候你不得不把庫順序來回調整。我也遇到了這樣讓人崩潰的情形,問題是對于liba.ar和libb.ar相互以來的情形,你可能最終采取丑陋的做法,將其中一個庫在前后放兩次:
gcc -o out.bin liba.ar libb.ar liba.ar -lrt
否則,您將不得不面對 "xx not referenced"之類的錯誤。

看看gcc的幫助,有下面的選項
-Xlinker option
           Pass option as an option to the linker.  You can use this to supply
           system-specific linker options which GCC does not know how to rec-
           ognize.

           If you want to pass an option that takes an argument, you must use
           -Xlinker twice, once for the option and once for the argument.  For
           example, to pass -assert definitions, you must write -Xlinker
           -assert -Xlinker definitions.  It does not work to write -Xlinker
           "-assert definitions", because this passes the entire string as a
           single argument, which is not what the linker expects.

也就是說,-Xlinker是將連接選項傳給連接器的,趕快看看ld的幫助有沒有解決庫順序的選項吧:
 -( archives -)
       --start-group archives --end-group
           The archives should be a list of archive files.  They may be either
           explicit file names, or -l options.

           The specified archives are searched repeatedly until no  new  unde-
           fined  references  are  created.   Normally, an archive is searched
           only once in the order that it is specified on  the  command  line.
           If  a symbol in that archive is needed to resolve an undefined sym-
           bol referred to by an object in an archive that  appears  later  on
           the command line, the linker would not be able to resolve that ref-
           erence.  By grouping the archives, they all be searched  repeatedly
           until all possible references are resolved.

           Using  this  option has a significant performance cost.  It is best
           to use it only  when  there  are  unavoidable  circular  references
           between two or more archives.


不錯,我們有個有點怪異的選項,-(和-),它能夠強制"The specified archives are searched repeatedly"
god,這就是我們要找的啦。

最終的做法:
gcc -o output.bin -Xlinker "-(" liba.ar libb.ar -Xlinker "-)" -lrt

這樣可以解決庫順序的問題了!問題是,如果你的庫相互間的依賴如果錯綜復雜的話,可能會增加連接的時間,不過,做架構設計的都應該能考慮到這些問題吧。








Feedback

# re: gcc 庫順序問題解決方法  回復  更多評論   

2008-11-09 18:43 by 踏雪赤兔
好物,謝~

# re: gcc 庫順序問題解決方法  回復  更多評論   

2009-04-22 13:43 by sxg
受教了,謝謝!

# re: gcc 庫順序問題解決方法[未登錄]  回復  更多評論   

2011-07-12 06:13 by Andrew
Thanks!
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久久久国产精品一区| 久久亚洲春色中文字幕久久久| 久久在线观看视频| 久久午夜精品| 亚洲精品一区二区三区樱花| 亚洲人成网站色ww在线| 欧美激情在线观看| 亚洲一区二区三区四区视频| 亚洲综合激情| 国产在线精品成人一区二区三区| 美女视频一区免费观看| 欧美激情一区在线| 亚洲欧美日韩区| 欧美一区二区三区视频免费| 亚洲二区在线观看| 亚洲精品自在在线观看| 国产精品日韩精品| 免费成人高清| 欧美视频在线观看免费网址| 久久国产精品黑丝| 欧美成人情趣视频| 欧美一区二区观看视频| 乱码第一页成人| 亚洲中午字幕| 老色批av在线精品| 欧美一级电影久久| 欧美xxxx在线观看| 欧美一站二站| 欧美韩国日本综合| 久久久精品tv| 欧美调教vk| 欧美高清在线一区二区| 国产美女高潮久久白浆| 亚洲激情黄色| 精品99一区二区| 亚洲欧美激情视频在线观看一区二区三区| 影音先锋亚洲视频| 亚洲男女自偷自拍图片另类| 夜夜夜精品看看| 久久人人超碰| 久久精彩视频| 国产精品狼人久久影院观看方式| 欧美激情亚洲| 伊人久久亚洲美女图片| 午夜精品亚洲| 欧美一区二区免费| 欧美色综合天天久久综合精品| 牛人盗摄一区二区三区视频| 国产午夜精品麻豆| 亚洲视频一区| 亚洲一区二区少妇| 欧美日韩成人在线播放| 欧美激情视频一区二区三区在线播放 | 亚洲黄色高清| 欧美在线一区二区三区| 欧美影院成人| 国产区日韩欧美| 亚洲天天影视| 午夜精品三级视频福利| 国产精品久久久一区麻豆最新章节| 亚洲国产一区二区三区青草影视| 一区精品在线| 久久综合久久综合久久| 欧美岛国在线观看| 亚洲激情在线激情| 欧美成人免费在线| 亚洲三级电影在线观看| 一区二区av在线| 欧美日韩福利| 中文一区二区| 欧美在线3区| 国产综合色精品一区二区三区| 午夜精品福利一区二区三区av | 久久久www成人免费精品| 国产欧美日韩综合一区在线播放 | 欧美不卡在线| 亚洲精品日韩欧美| 欧美午夜不卡在线观看免费| 亚洲小视频在线| 久久国产精品久久w女人spa| 在线播放豆国产99亚洲| 免费在线国产精品| 亚洲精品乱码久久久久久日本蜜臀 | 欧美另类亚洲| 亚洲午夜一区| 免费不卡在线观看| 亚洲午夜免费视频| 国产精品一区二区久久久久| 久久精品99久久香蕉国产色戒| 欧美不卡高清| 亚洲午夜久久久| 国内久久精品视频| 欧美搞黄网站| 欧美一区二区在线| 亚洲高清电影| 欧美伊人久久久久久久久影院| 亚洲国产成人精品久久久国产成人一区| 美女黄毛**国产精品啪啪| 99精品久久免费看蜜臀剧情介绍| 久久精品毛片| 一区二区三区精品视频在线观看 | 欧美日韩激情网| 欧美中文字幕不卡| 亚洲精品免费观看| 久久天天综合| 亚洲一区二区精品视频| 亚洲国产福利在线| 国产精品夜夜嗨| 欧美激情免费在线| 久久精品91| 亚洲视频精选| 亚洲高清免费在线| 久久精品国产免费观看| 一区二区不卡在线视频 午夜欧美不卡在| 国产精品亚发布| 欧美日韩国产一区二区三区| 久久久久久久欧美精品| 亚洲午夜伦理| 亚洲裸体视频| 最新日韩在线视频| 欧美大片网址| 久久精品一区二区三区四区| 亚洲一区二区三区四区五区午夜 | 美女日韩在线中文字幕| 欧美一区二区私人影院日本| 一本色道久久综合狠狠躁篇怎么玩| 国产专区欧美专区| 国产精品专区h在线观看| 欧美三级网页| 欧美日韩综合在线| 欧美精品成人91久久久久久久| 久久一综合视频| 久久国产免费看| 午夜精品一区二区三区在线播放| 在线一区二区三区四区| 99精品99| 一区二区三区你懂的| 日韩视频在线一区| 日韩午夜在线电影| 日韩网站在线| 亚洲美女区一区| 日韩亚洲视频| 一区二区三区四区精品| 亚洲视频一二区| 亚洲嫩草精品久久| 欧美一区二区高清| 久久精品九九| 蜜臀a∨国产成人精品| 欧美激情国产精品| 欧美日韩一级大片网址| 欧美性色视频在线| 国产精品综合| 狠狠色狠狠色综合人人| 亚洲国产精品久久久久秋霞蜜臀 | 亚洲一级免费视频| 亚洲尤物视频网| 欧美中文日韩| 欧美+亚洲+精品+三区| 欧美人与性动交a欧美精品| 欧美日韩免费观看一区| 国产精品一区三区| 狠狠综合久久| 亚洲美女电影在线| 亚洲女优在线| 久久亚洲欧美| 亚洲精品日产精品乱码不卡| 亚洲午夜小视频| 久久综合中文| 欧美午夜视频一区二区| 国产日韩视频一区二区三区| 亚洲国产美女| 亚洲免费婷婷| 欧美ed2k| 亚洲一级网站| 欧美国产精品中文字幕| 国产精品毛片在线看| 在线观看日韩av先锋影音电影院| 99国产精品国产精品久久| 午夜精品在线看| 欧美大秀在线观看| 亚洲欧美中文字幕| 欧美成人免费视频| 国产一区二区三区四区老人| 日韩视频在线一区二区三区| 香港成人在线视频| 亚洲国产精品一区在线观看不卡| 午夜精品999| 欧美日本精品| 激情欧美一区| 性欧美暴力猛交69hd| 亚洲精华国产欧美| 久久精品日韩欧美| 国产精品久久久久影院亚瑟| 亚洲欧洲精品一区二区三区 | 亚洲一区二区毛片| 亚洲国产日韩欧美在线图片| 久久gogo国模裸体人体| 欧美性一二三区| 日韩写真视频在线观看| 美女视频黄a大片欧美|