【柔性數(shù)組結(jié)構(gòu)成員
C99中,結(jié)構(gòu)中的最后一個元素允許是未知大小的數(shù)組,這就叫做柔性數(shù)組成員,但結(jié)構(gòu)中的柔性數(shù)組成員前面必須至少一個其 他成員。柔性數(shù)組成員允許結(jié)構(gòu)中包含一個大小可變的數(shù)組。sizeof返回的這種結(jié)構(gòu)大小不包括柔性數(shù)組的內(nèi)存。包含柔性數(shù)組成員的結(jié)構(gòu)用malloc ()函數(shù)進(jìn)行內(nèi)存的動態(tài)分配,并且分配的內(nèi)存應(yīng)該大于結(jié)構(gòu)的大小,以適應(yīng)柔性數(shù)組的預(yù)期大小。】
C語言大全,“柔性數(shù)組成員”
【柔性數(shù)組結(jié)構(gòu)成員
C99中,結(jié)構(gòu)中的最后一個元素允許是未知大小的數(shù)組,這就叫做柔性數(shù)組成員,但結(jié)構(gòu)中的柔性數(shù)組成員前面必須至少一個其 他成員。柔性數(shù)組成員允許結(jié)構(gòu)中包含一個大小可變的數(shù)組。sizeof返回的這種結(jié)構(gòu)大小不包括柔性數(shù)組的內(nèi)存。包含柔性數(shù)組成員的結(jié)構(gòu)用malloc ()函數(shù)進(jìn)行內(nèi)存的動態(tài)分配,并且分配的內(nèi)存應(yīng)該大于結(jié)構(gòu)的大小,以適應(yīng)柔性數(shù)組的預(yù)期大小。】
C語言大全,“柔性數(shù)組成員”
看看 C99 標(biāo)準(zhǔn)中 靈活數(shù)組成員:
結(jié)構(gòu)體變長的妙用——0個元素的數(shù)組
有時(shí)我們需要產(chǎn)生一個結(jié)構(gòu)體,實(shí)現(xiàn)了一種可變長度的結(jié)構(gòu)。如何來實(shí)現(xiàn)呢?
看這個結(jié)構(gòu)體的定義:
typedef struct st_type
{
int nCnt;
int item[0];
}type_a;
(有些編譯器會報(bào)錯無法編譯可以改成:)
typedef struct st_type
{
int nCnt;
int item[];
}type_a;
這樣我們就可以定義一個可變長的結(jié)構(gòu),用sizeof(type_a)得到的只有4,就是sizeof(nCnt)=sizeof(int)那 個0個元素的數(shù)組沒有占用空間,而后我們可以進(jìn)行變長操作了。
C語言版:
type_a *p = (type_a*)malloc(sizeof(type_a) + 100*sizeof(int));
C++語言版:
type_a *p = (type_a*)new char[sizeof(type_a) + 100*sizeof(int)];
這樣我們就產(chǎn)生了一個長為100的type_a類型的東西用p->item[n]就能簡單地訪問可變長元素,原理十分簡單 ,分配了比sizeof(type_a)多的內(nèi)存后int item[];就有了其意義了,它指向的是int nCnt;后面的內(nèi)容,是沒 有內(nèi)存需要的,而在分配時(shí)多分配的內(nèi)存就可以由其來操控,是個十分好用的技巧。
而釋放同樣簡單:
C語言版:
free(p);
C++ 語言版:
delete []p;
其實(shí)這個叫靈活數(shù)組成員(fleible array member)C89不支持這種東西,C99把它作為一種特例加入了標(biāo)準(zhǔn)。但 是,C99所支持的是incomplete type,而不是zero array,形同int item[0];這種形式是非法的,C99支持的 形式是形同int item[];只不過有些編譯器把int item[0];作為非標(biāo)準(zhǔn)擴(kuò)展來支持,而且在C99發(fā)布之前已經(jīng)有 了這種非標(biāo)準(zhǔn)擴(kuò)展了,C99發(fā)布之后,有些編譯器把兩者合而為一。