柔性数组的几个特点:
1.必须在结构体中
2.在结构体的最后面
3.结构体除了柔性数组至少还要有一个其他成员
4.sizeof (编译器决定大小)返回结构体的大小不包含柔性数组
5.malloc
6.free
struct sdshdr16 {
uint16_t len;
uint16_t alloc;
unsigned char flags;
char buf[];
};
//非柔性数组的方式
struct sdshdr16 {
uint16_t len;
uint16_t alloc;
unsigned char flags;
char *buf;
};
柔性数组只需要分配一次,
struct sdshdr16 *p = malloc(sizeof(sdshdr16) + 柔性数组大小)
free§; //free一次
柔性数组放在最后其实就是一个语法糖,告诉编译器,这块内存要动态分配
而普通指针需要malloc和free两次
malloc(sizeof(sdshdr16))
malloc(buf的大小)
既然柔性数组的大小是运行时确定的,那free怎么知道要释放多大呢?
其实在malloc分配后,会在前面有16字节存放长度,free时先向前偏移16字节,找到长度,在释放。
柔性数组优点:
1.方便内存分配释放
2.减少内存碎片