3 回答

TA貢獻(xiàn)1951條經(jīng)驗(yàn) 獲得超3個(gè)贊
這是C99的功能,稱為靈活數(shù)組,主要功能是允許使用可變長(zhǎng)度數(shù)組,如struct和R. 內(nèi)部的功能。在對(duì)靈活數(shù)組成員的另一個(gè)問(wèn)題的回答中,提供了使用靈活數(shù)組而不是指針的一系列好處。該草案C99標(biāo)準(zhǔn)的部分6.7.2.1 結(jié)構(gòu)和聯(lián)合說(shuō)明段16說(shuō):
作為一種特殊情況,具有多個(gè)命名成員的結(jié)構(gòu)的最后一個(gè)元素可能具有不完整的數(shù)組類(lèi)型;這稱為靈活數(shù)組成員。在大多數(shù)情況下,柔性數(shù)組成員將被忽略。特別地,該結(jié)構(gòu)的尺寸就好像省略了柔性陣列構(gòu)件,除了其可能具有比省略所暗示的更多的尾隨填充。[...]
因此,如果您有一個(gè)s*,除了為struct所需的空間外,您還將為數(shù)組分配空間,通常在結(jié)構(gòu)中還會(huì)有其他成員:
s *s1 = malloc( sizeof(struct s) + n*sizeof(int) ) ;
該標(biāo)準(zhǔn)草案實(shí)際上在第17段中具有指導(dǎo)性的示例:
示例聲明后:
struct s { int n; double d[]; };
結(jié)構(gòu)struct s具有靈活的數(shù)組成員d。一種典型的使用方法是:
int m = /* some value */;
struct s *p = malloc(sizeof (struct s) + sizeof (double [m]));
并假設(shè)malloc成功調(diào)用了該對(duì)象所指向的對(duì)象p ,在大多數(shù)情況下,其行為就像p已聲明為:
struct { int n; double d[m]; } *p;
(在某些情況下,此等價(jià)關(guān)系將被破壞;尤其是,成員的偏移量d可能會(huì)不同)。

TA貢獻(xiàn)1785條經(jīng)驗(yàn) 獲得超4個(gè)贊
我很好奇Dennis Ritchie將提倡什么而不是struct hack?恕我直言,最好的選擇是使編譯器不擁擠零大小的數(shù)組聲明,在這種情況下,編譯器可以安全地假設(shè),如果結(jié)構(gòu)中的數(shù)組的聲明大小為N
,則不會(huì)嘗試訪問(wèn)任何元素超出N-1u
空間或占用空間的最后一個(gè),以較低者為準(zhǔn)。
- 3 回答
- 0 關(guān)注
- 796 瀏覽
添加回答
舉報(bào)