• <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>
            渴望飛翔
            Fly in the C++ Sky...
            posts - 9,  comments - 6,  trackbacks - 0

            在C++中經(jīng)常會(huì)涉及到處于不同頭文件的類(lèi)互相引用的情況,有時(shí)候頭文件引用(include)會(huì)搞得很亂,導(dǎo)致報(bào)一堆的錯(cuò)。其實(shí)遵循一定規(guī)則,可以避免大部分的混亂。

            首先,要對(duì)頭文件進(jìn)行處理,保證不會(huì)出現(xiàn)重定義的錯(cuò)誤。這個(gè)應(yīng)該每個(gè)人都會(huì),通常有兩種做法:

            1. 在.cpp文件中添加保護(hù),比如在.cpp文件中添加:

            #ifndef _XX_H_
            #define _XX_H_
            #include "xx.h"
            #endif

            2. 在.h中添加保護(hù),比如在xx.h文件中添加:

            #ifndef _XX_H_
            #define _XX_H_
            // 頭文件聲明內(nèi)容
            #endif

            _XX_H_是我比較習(xí)慣的命名方式,其他的命名方式,比如__XX__H__,XX_H等等,只要足夠Unique就好。建議使用第二種方式進(jìn)行重定義的保護(hù),一勞永逸而且具有通用性,任何人拿來(lái)就能用,不需要考慮保護(hù)問(wèn)題。當(dāng)然,如果在VS(03以上吧?)下,最好的解決方案是用#pragma once,更為簡(jiǎn)單有效。

            其次,最好將所有頭文件需要用到的自定義類(lèi)(或函數(shù))都在定義前聲明一下,比如在xx.h的類(lèi)xx中需要用到y(tǒng)y.h中的yy類(lèi),那么最好做以下的處理:

            class yy;

            class xx
            {
             // 實(shí)現(xiàn)內(nèi)容
            };

            這樣就可以保證頭文件引用的次序不會(huì)對(duì)結(jié)果造成影響。

            通常,保證以上兩點(diǎn),通常涉及到類(lèi)互指的問(wèn)題都可以解決。當(dāng)然如果天生就有設(shè)計(jì)問(wèn)題,無(wú)論如何都是沒(méi)有辦法的,比如:

            // xx.h
            class xx
            {
             yy t;
            };

            // yy.h
            class yy
            {
             xx t;
            };

            不難看出,這是個(gè)遞歸定義,編譯器無(wú)法確定類(lèi)xx和yy的大小,就無(wú)法通過(guò)編譯。一種解決策略是采用指針,比如:

            // xx.h
            class xx
            {
             yy* t;
            };

            // yy.h
            class yy
            {
             xx* t;
            };

            當(dāng)然,具體情況具體分析,提取一個(gè)更高層的類(lèi)等手段都可以考慮。

            還有一個(gè)問(wèn)題,我一直也心存疑問(wèn),就是頭文件組織問(wèn)題。在VS中建立一個(gè)MFC工程,都會(huì)產(chǎn)生一對(duì)stdafx文件,按照這種思想我們把工程下通用的頭文件都放入stdafx.h中,在.cpp文件的最開(kāi)始統(tǒng)一#include "stdafx.h",這樣就可以在.h文件中引用很少的頭文件。

            這種策略在單工程時(shí)很好用,相當(dāng)于做了頭文件組織級(jí)別的重用,但它違反了我一直恪守的一個(gè)原則即誰(shuí)的頭文件誰(shuí)負(fù)責(zé),指.h和.cpp各自負(fù)責(zé)各自所需的頭文件。于是在跨工程的時(shí)候會(huì)出現(xiàn)一些問(wèn)題。比如在B工程B的某個(gè).h中引用了工程B中的一個(gè)頭文件,由于編譯次序問(wèn)題,這個(gè)頭文件可能無(wú)法被編譯。不知道大家都如何處理頭文件組織問(wèn)題的,望指教。



            duguguiyu 2007-07-21 19:37 發(fā)表評(píng)論

            文章來(lái)源:http://www.cnblogs.com/duguguiyu/archive/2007/07/21/826821.html
            posted on 2007-07-21 19:37 duguguiyu 閱讀(622) 評(píng)論(1)  編輯 收藏 引用 所屬分類(lèi): MFC

            FeedBack:
            # re: 互引頭文件的一種解決策略
            2009-01-13 13:07 | sfsf
            very nice  回復(fù)  更多評(píng)論
              
            Welcome to my c++ home...

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(1)

            隨筆分類(lèi)(9)

            隨筆檔案(9)

            搜索

            •  

            積分與排名

            • 積分 - 10593
            • 排名 - 1154

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久经典免费视频| 日韩精品国产自在久久现线拍| 久久精品成人免费观看97| 久久人人爽人人精品视频| 亚洲国产高清精品线久久| 久久精品国产亚洲AV忘忧草18| 少妇内射兰兰久久| 国产精品久久久99| 久久精品麻豆日日躁夜夜躁| 久久中文字幕一区二区| 久久99国产精品久久99小说| 人人狠狠综合久久88成人| 成人精品一区二区久久久| 久久AV无码精品人妻糸列| 国产69精品久久久久777| 99久久国产主播综合精品| 亚洲精品高清国产一线久久| 国产精品免费久久久久影院| 久久久精品人妻一区二区三区四| 久久久久久久综合综合狠狠| 99久久777色| 综合网日日天干夜夜久久| 久久久久亚洲AV成人网人人软件| 久久男人Av资源网站无码软件| 欧美粉嫩小泬久久久久久久| 久久99热国产这有精品| 久久久久AV综合网成人 | 亚洲va国产va天堂va久久| 狠狠色伊人久久精品综合网| 久久久久国产精品熟女影院 | 日本五月天婷久久网站| 久久精品中文字幕第23页| 久久99国产亚洲高清观看首页| 777午夜精品久久av蜜臀 | 岛国搬运www久久| 99久久免费国产精品| 国产精品一区二区久久不卡| 日韩AV无码久久一区二区| 亚洲AV无码久久精品色欲| 精品国产青草久久久久福利| 国产偷久久久精品专区|