柔性数组成员
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。
 如何使用还是需要结合具体情况。










