• <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)系來生成對(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ǔ)庫,已經(jīng)比較穩(wěn)定了,除了一些少量的BUG FIX外,很少需要修改,當(dāng)你通過源碼形式引用的時(shí)候,你當(dāng)然不希望每次編譯的時(shí)候都去編譯
            這些基礎(chǔ)庫,如是你決定將他們加入預(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 閱讀(1959) 評(píng)論(0)  編輯 收藏 引用 所屬分類: c++

            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            精品综合久久久久久888蜜芽| 国产V亚洲V天堂无码久久久| 久久精品国产一区二区三区| 精品久久久久久无码中文野结衣| 久久久久国产日韩精品网站| 久久亚洲精品成人无码网站| 国产精品无码久久综合| 99久久精品国产毛片| 伊人色综合久久天天网| 国产精品久久久久jk制服| 欧美精品丝袜久久久中文字幕 | 亚洲精品无码久久千人斩| 91精品国产综合久久久久久| 久久久久亚洲av毛片大| 久久久久人妻一区精品色| 色婷婷狠狠久久综合五月| 九九99精品久久久久久| 亚洲中文久久精品无码ww16| 精品久久久久久久久久中文字幕| 久久精品中文无码资源站| 亚洲国产精品综合久久一线| 一本久久a久久精品综合夜夜 | 久久精品国产亚洲AV久| 久久亚洲综合色一区二区三区| 东方aⅴ免费观看久久av| 久久久久亚洲AV成人网| 99久久99久久精品国产片果冻| 久久天天躁狠狠躁夜夜网站| 国内精品综合久久久40p| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久综合综合久久综合| 欧美日韩久久中文字幕| 欧美亚洲另类久久综合婷婷| 久久国产V一级毛多内射| 99久久国产综合精品成人影院 | 久久夜色精品国产噜噜噜亚洲AV| 久久伊人精品一区二区三区| 久久精品aⅴ无码中文字字幕不卡| 国产精品久久久久久久app| 亚洲精品午夜国产va久久| 国产精品久久久香蕉|