我有一个三维位表数组
bit_table[dim1][100][200];
第二维度和第三维度总是一样的。
但dim1必须随着时间的推移而增长。
当这个bit_table满时,它的大小需要在dim1维度中增长,而旧内容需要保留。
为了保留表的旧内容,我应该创建一个临时数组,将旧的数组数据复制到它,并且在扩展数组之后,复制这个数据吗?还是有更好的方法来做呢?
编辑:
int dim1=10;
unsigned char (*bit_table)[100][200] = (unsigned char)malloc(dim1 * sizeof(*bit_table));
printf("enter new dimension\n");
scanf(dim1);……
发布于 2012-03-27 12:59:31
你可以这样做:
int (*bit_table)[100][200] = malloc(dim1 * sizeof(*bit_table));
...
bit_table = realloc(bit_table, dim1_new * sizeof(*bit_table));
...
free(bit_table);显然,这两个调用都需要适当的错误处理。特别是,如果realloc失败(在上面的代码中),那么您将导致内存泄漏。
发布于 2012-03-27 14:00:56
对不起,我没看到这里有什么特殊的困难。除了查尔斯沃思提到的realloc。您还可以:
typedef unsigned char bit_table_elem[100][200];
// if you're using c, linked list will be a good choice
// but if you really need indexing, then use the realloc way...
struct bit_table_list {
bit_table_elem elem;
struct bit_table_list* next;
}
// if you're using c++, std vector will be better
std::vector<bit_table_elem> bit_tablehttps://stackoverflow.com/questions/9889948
复制相似问题