我有一个问题,我正在使用sourgery c++工具链,编译器让我写这句话:
for(i=0;i<size_of_categories;i++){
size_t size_of_tmp = sizeof(char) * (HOSTLINK_CONFIG_STRING_MAX_LEN * (categories[i].key_len));
char tmp[size_of_tmp];
memset(tmp,0,(size_of_tmp));
get_hostlink_count[i]++;
if(categories[i].time == get_hostlink_count[i]){
if(format == CSV){
csv_this_category_values(categories,i,tmp,size_of_tmp);
strncat(buffer,tmp,buff_len);
}else if (format == JSON){
xi_json_this_category_values(categories,i,tmp,size_of_tmp);
js_this_cat = json_loads(tmp,JSON_DECODE_ANY,NULL);
json_array_extend(js_arr,js_this_cat);
json_array_clear(js_this_cat);
json_decref(js_this_cat);
}
get_hostlink_count[i] = 0;
}
//Free(tmp);
}
我的问题是这句话是在堆栈中还是在堆中分配内存?这可能会导致内存泄漏,因为它是在for循环中生成的?这相当于制作一个malloc,并在循环结束时生成一个Free吗?
size_t size_of_tmp = sizeof(char) * (HOSTLINK_CONFIG_STRING_MAX_LEN * (categories[i].key_len));
char tmp[size_of_tmp];
由于您没有执行任何malloc
s,因此在这段特定的代码中不会出现内存泄漏。但是,不能用非常量大小声明tmp
数组。也就是说,你不能说char tmp[size_of_tmp]
和size_of_tmp
不是常数(这不是因为它依赖于categories[i].key_len
)。
可以使用malloc
或calloc
为堆上的数组分配内存,如
char *tmp = (char*)malloc(size_of_tmp);
或者这个
char *tmp = (char*)calloc(size_of_tmp, sizeof(char));
calloc
已经将所有分配的内存初始化为零,因此不必使用memset
。
如果你想避免内存泄漏,你必须在每次循环迭代结束时free
分配的tmp
数组。