轉(zhuǎn):
c/c++ 前置聲明 -- typedef問題c/c++ 前置聲明 -- typedef問題
cc++類結(jié)構(gòu)體typedef前置聲明
前置聲明的好處很多, 比如能避免頭文件互相包含的沖突, 比如有時(shí)我們在一個(gè)頭文件中只需要另一個(gè)頭文件的某個(gè)類型定義, 只需要對(duì)它做一下前置聲明即可,
因?yàn)闉榱讼鄬?duì)較小的目的要包含進(jìn)來一個(gè)很大的頭文件, 實(shí)在有些"不值", 況且這個(gè)頭文件可能還要被其它很多文件再包含的, 這樣代價(jià)就更大了.
所以做前置聲明即可, 在源文件真正需要的時(shí)候再包含那個(gè)頭文件.
之前也聲明過類和c++方式定義的struct, 今天遇到了一個(gè)typedef的結(jié)構(gòu)體, 結(jié)果前置聲明不奏效了.
網(wǎng)上查了些資料, 有的帖子沒有討論出結(jié)果, 有的直接定性typedef的不能前置聲明, 只能include進(jìn)來.
幸好自己寫小例子多測試了一會(huì), 發(fā)現(xiàn)語法上還是支持的. 舉例如下:
#a.h:
typedef struct my_time_t
{
int hour, minute, second;
} MY_TIME;
#b.h
struct my_time_t;
typedef struct my_time_t MY_TIME;
void func(MY_TIME* mt) {}
#main.cpp
#include "a.h"
#include "b.h"
int main()
{
MY_TIME mt;
func(&mt);
return 0;
}
這樣就可以成功了. 在b.h中做前置聲明時(shí), 先聲明有my_time_t這樣一個(gè)struct, 然后說明MY_TIME是由那個(gè)結(jié)構(gòu)體typedef出來的,
這樣void func(MY_TIME* mt);這個(gè)函數(shù)聲明就能編譯通過了. 直接做struct MY_TIME;這樣的前置聲明是不被接受的.