您好,登錄后才能下訂單哦!
這篇文章給大家介紹C++中怎么重用頭文件,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
在實際編程中,不同的類一般是放在不同的相互獨立的C++頭文件中的,這樣兩個類在相互引用時又會有不一樣的問題。重復編譯是問題出現的根本原因。為了保證頭文 件僅被編譯一次,在C++中常用的辦法是使用條件編譯命令。
Example: animal.h class animal { ...... }; animal.cpp #include "animal.h" #include <iostream.h> ...... fish.h #include "animal.h" class fish { ...... }; fish.cpp #include "fish.h" #include <iostream.h> ...... main.cpp #include "animal.h" #include "fish.h" void main() { ...... }
編譯文件,會出現class type redefinition的錯誤
為什么會出現類重復定義的錯誤呢?請讀者仔細查看EX10.cpp文件,在這個文件中包含了animal.h和fish.h這兩個頭文件。當編譯器編譯EX10.cpp文件時,因為在文件中包含了animal.h頭文件,編譯器展開這個C++頭文件,知道animal這個類定義了,接著展開fish.h 頭文件,而在fish.h頭文件中也包含了animal.h,再次展開animal.h,于是animal這個類就重復定義了。
要解決C++頭文件重復包含的問題,可以使用條件預處理指令。修改后的頭文件如下:
animal.h #ifndef ANIMAL_H_H #define ANIMAL_H_H class animal { ...... }; #endif fish.h #include "animal.h" #ifndef FISH_H_H #define FISH_H_H class fish { ...... }; #endif
我們再看EX10.cpp的編譯過程。當編譯器展開animal.h頭文件時,條件預處理指令判斷ANIMAL_H_H沒有定義,于是就定 義它,然后繼續執行,定義了animal這個類;接著展開fish.h頭文件,而在fish.h頭文件中也包含了animal.h,再次展開 animal.h,這個時候條件預處理指令發現ANIMAL_H_H已經定義,于是跳轉到#endif,執行結束。
但是不要以為使用了這種機制就全部搞定了,比如在以下的代碼中:
//文件A.h中的代碼 #pragma once #include "B.h" class A { public: B* b; }; //文件B.h中的代碼 #pragma once #include "A.h" class B { public: A* a; };
這里兩者都使用了指針成員,因此嵌套本身不會有什么問題,在主函數前面使用#include "A.h"之后,主要編譯錯誤如下:
error C2501: 'A' : missing storage-class or type specifiers
仍然是類型不能找到的錯誤。其實這里仍然需要前置聲明。分別添加前置聲明之后,可以成功編譯了。代碼形式如下:
//文件A.h中的代碼 #pragma once #include "B.h" class B; class A { public: B* b; }; //文件B.h中的代碼 #pragma once #include "A.h" class A; class B { public: A* a; };
關于C++中怎么重用頭文件就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。