• <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>

            gifty

            GCC預(yù)編譯頭技術(shù)

            最近在弄GCC的預(yù)編譯頭,用C++開發(fā)工程最難以忍受的就是烏龜似地的編譯速度,用VC開發(fā)工程的時(shí)候,VC會(huì)默認(rèn)幫我們引入預(yù)編譯頭,那么GCC呢?其實(shí)GCC也是支持預(yù)編譯頭得, http://lych.yo2.cn/articles/淺談gcc預(yù)編譯頭技術(shù).html 這篇文章就詳細(xì)講解了如何GCC下預(yù)編譯頭得一些知識(shí), 所以具體如何在GCC中加入預(yù)編譯頭,大家可以參考這篇文章。

            在給GCC添加預(yù)編譯頭時(shí)也遇到了一些問題,并且對(duì)C++/C的編譯有了一些新的認(rèn)識(shí)!


            很多在linux下寫程序的人都應(yīng)該看過《和我一起寫Makefile》這篇文章,里面講過如何利用GCC的-MM選項(xiàng)自動(dòng)生成依賴:


            %.d: %.cpp
            @$(GPP) -MM $(INCLUDE) $< > $@.tmp;\
            sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.tmp > $@;\
            rmf $@.tmp


            這里利用了一個(gè)模式規(guī)則,將CPP文件依賴的頭文件寫到一個(gè).d文件中,執(zhí)行Makefile時(shí)我們只需要include這些.d文件,GCC就會(huì)根據(jù)里面的依賴關(guān)系來(lái)生成對(duì)應(yīng)的.o文件了!
            但是實(shí)際上GCC的自動(dòng)推導(dǎo)能力非常強(qiáng)大,我們其實(shí)只需要寫下一條這樣的模式就可以了,
            %.o:%.cpp
            @$(GPP) $(CPPFLAGS) $< $(INCLUDE)


            GCC就會(huì)自動(dòng)推導(dǎo)出CPP文件所需要依賴的頭文件進(jìn)行編譯了!


            如果你在自己的工程中加入了預(yù)編譯頭,你就必須使用下面一種模式。
            舉個(gè)例子,比如你們工程開發(fā)了一些基礎(chǔ)庫(kù),已經(jīng)比較穩(wěn)定了,除了一些少量的BUG FIX外,很少需要修改,當(dāng)你通過源碼形式引用的時(shí)候,你當(dāng)然不希望每次編譯的時(shí)候都去編譯
            這些基礎(chǔ)庫(kù),如是你決定將他們加入預(yù)編譯頭中去,但是當(dāng)你使用第一種方式寫Makefile的時(shí)候,你發(fā)現(xiàn)被你加入到預(yù)編譯頭中的頭文件還是被重復(fù)編譯了,因?yàn)?MM選項(xiàng)會(huì)把你CPP文件
            依賴的非系統(tǒng)頭文件全部放在對(duì)應(yīng)的.d文件中。但是當(dāng)你使用第二種Makefile時(shí),GCC看到一個(gè)預(yù)編譯頭后,他不會(huì)按照常規(guī)的方式將它展開,而是回去尋找對(duì)應(yīng)的.gch文件,然后進(jìn)行編譯,
            如果你想一探究竟的話,編譯加上-H選項(xiàng)就可以看出其中的差異了!

            這樣生成的預(yù)編譯頭如果要使用的話,需要和編譯CPP文件使用相同的選項(xiàng),否則后出現(xiàn)一些奇怪的編譯錯(cuò)誤,我的做法是寫一個(gè)預(yù)編譯頭得模式:

            %.h.gch:%.h
            $(GPP) $(CPPFLAGS) $< $(INCLUDE)

            posted on 2011-05-02 15:50 gifty 閱讀(1969) 評(píng)論(0)  編輯 收藏 引用 所屬分類: c++

            <2011年5月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            999久久久无码国产精品| 色综合色天天久久婷婷基地| 2021最新久久久视精品爱| 亚洲人成无码网站久久99热国产| 亚洲精品乱码久久久久久按摩| 99久久99久久精品免费看蜜桃| 国产99久久九九精品无码| 久久久亚洲裙底偷窥综合| 成人国内精品久久久久影院VR| 久久精品免费一区二区| 国产精品久久久99| 久久精品黄AA片一区二区三区| 久久人妻少妇嫩草AV无码蜜桃| 99久久国语露脸精品国产| 亚洲精品国产第一综合99久久| 国产成人AV综合久久| 久久成人国产精品二三区| 久久久亚洲欧洲日产国码aⅴ| 亚洲午夜福利精品久久| 久久国产精品一区| 99久久99久久精品国产| 久久亚洲高清观看| 久久精品www| 精品久久香蕉国产线看观看亚洲| 无码人妻少妇久久中文字幕蜜桃| 久久久久久国产精品无码下载| 精品久久久久成人码免费动漫| 色综合久久久久综合99| 亚洲国产成人久久综合一 | 国产亚洲精午夜久久久久久| 久久无码人妻一区二区三区午夜| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 99久久综合狠狠综合久久止| 亚洲精品乱码久久久久久蜜桃不卡 | 久久久高清免费视频| 一本大道久久香蕉成人网| 久久亚洲2019中文字幕| 一级女性全黄久久生活片免费 | 欧美亚洲国产精品久久高清| 久久久久一本毛久久久| 国产精品一区二区久久精品涩爱 |