例如有 void* old_addr = ...; unsigned int old_size = ...; void* new_addr = realloc(old_addr, new_size)
1 返回值new_addr不为NULL的情况:
1)old_addr != NULL && new_size < old_size:紧缩并释放后面的部分(new_size - old_size)内存,紧缩内存索引,
返回old_addr, 即此时new_addr == old_addr
2) old_addr != NULL && new_size > old_size && old_addr后面有!足够大的可用内存扩展到new_size,则扩展分配之,
扩大内存索引,返回old_addr, 即此时new_addr == old_addr
3)old_addr != NULL && new_size > old_size && old_addr后面没!有!足够大的可用内存扩展到new_size,
则在堆内存其他处分配, 拷贝&释!放!old_addr,返回新的内存地址, 即此时new_addr != old_addr,不能再free(old_addr)
4) old_addr == NULL && new_size > 0, 就如!同!molloc(new_size)了
2 返回值new_addr为NULL的情况:
1)old_addr != NULL && new_size == 0, 就如!同!free(old_addr )了, 返回NULL
2 )old_addr != NULL && new_size != 0, 分配 失! 败!,唯一失败的情况!