• <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++中經常會涉及到處于不同頭文件的類互相引用的情況,有時候頭文件引用(include)會搞得很亂,導致報一堆的錯。其實遵循一定規則,可以避免大部分的混亂。

            首先,要對頭文件進行處理,保證不會出現重定義的錯誤。這個應該每個人都會,通常有兩種做法:

            1. 在.cpp文件中添加保護,比如在.cpp文件中添加:

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

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

            #ifndef _XX_H_
            #define _XX_H_
            // 頭文件聲明內容
            #endif

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

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

            class yy;

            class xx
            {
             // 實現內容
            };

            這樣就可以保證頭文件引用的次序不會對結果造成影響。

            通常,保證以上兩點,通常涉及到類互指的問題都可以解決。當然如果天生就有設計問題,無論如何都是沒有辦法的,比如:

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

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

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

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

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

            當然,具體情況具體分析,提取一個更高層的類等手段都可以考慮。

            還有一個問題,我一直也心存疑問,就是頭文件組織問題。在VS中建立一個MFC工程,都會產生一對stdafx文件,按照這種思想我們把工程下通用的頭文件都放入stdafx.h中,在.cpp文件的最開始統一#include "stdafx.h",這樣就可以在.h文件中引用很少的頭文件。

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



            duguguiyu 2007-07-21 19:37 發表評論

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

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

            <2007年7月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(1)

            隨筆分類(9)

            隨筆檔案(9)

            搜索

            •  

            積分與排名

            • 積分 - 10632
            • 排名 - 1156

            最新評論

            閱讀排行榜

            評論排行榜

            综合久久国产九一剧情麻豆| 九九热久久免费视频| 伊人伊成久久人综合网777| 久久久黄色大片| 9久久9久久精品| 久久久国产精品| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久超乳爆乳中文字幕| 国产V综合V亚洲欧美久久| 青青草原综合久久大伊人精品| 久久人人爽人人爽人人片AV东京热| 久久精品aⅴ无码中文字字幕不卡| 99国产欧美精品久久久蜜芽| 国内精品伊人久久久久影院对白 | 91精品国产综合久久香蕉 | 99久久无码一区人妻| 狠狠色综合网站久久久久久久高清 | 久久久久人妻一区精品 | 国产精品久久久亚洲| 久久综合亚洲色HEZYO国产| 久久婷婷五月综合97色| 亚洲精品97久久中文字幕无码| 久久精品亚洲一区二区三区浴池| 亚洲精品成人久久久| 99久久精品免费| 久久无码av三级| 99久久99久久| 久久精品国产亚洲AV大全| 一本大道久久香蕉成人网| 狠狠综合久久综合中文88| 久久夜色精品国产亚洲| 国产成人久久精品激情| 狠狠色丁香久久婷婷综合五月| 无码AV中文字幕久久专区| 亚洲中文精品久久久久久不卡| 久久婷婷五月综合国产尤物app| 亚洲日本久久久午夜精品| 久久伊人精品青青草原日本| 久久精品国产亚洲精品| 久久av免费天堂小草播放| 国产午夜福利精品久久|