柔性数组成员
typedef struct
{
char a;
double b;
int c;
char ptr[0]; //柔性数组成员 不占空间
}Test;
内存分析:
优点一:
void main()
{
char str[] = "Hello Wrold";
Test* ptr = (Test*)malloc(sizeof(Test)+strlne(str)+1);
if(NULL == ptr)
{
printf("Out of Memory!\n");
return ;
}
//strcpy(pt->ptr,str);
printf("str = %s\n",ptr->ptr);
}
相比普通指针成员,柔型数组成员不但不占空间,而且可以开辟不定长大小的数组,这就是柔型数组开辟空间的优势所在。
若换成下面这个结构体
typedef struct
{
char a;
double b;
int c;
char* ptr; //指针
}Test;
ptr是指针类型,如果要使用ptr指向一个字符串,就需要给这个字符串动态开辟一块空间,使用ptr接收地址。这是一次malloc。
然后要对结构体动态开辟一块空间,这是第二次malloc。
而编写时,我们就会很容易忘记free掉ptr。导致内存泄漏。
相比之下,柔型数组的优点凸显。
而柔型数组的缺点也很明显,就是它能读取到的空间是不定的,因为不知道什么时候会遇到\0。
如何使用还是需要结合具体情况。