是否可以在C中“动态”分配文件指针? 我的意思是:
FILE **fptr;
fptr = (FILE **)calloc(n, sizeof(FILE*));
其中n是整数值。 我需要一个指针值数组,但在获得用户输入之前我不知道有多少,因此我无法对其进行硬编码。 任何帮助都会很精彩!
答案 0 :(得分:2)
您正在尝试实现有时称为灵活数组(或 flex array )的内容,即在程序生命周期内动态更改大小的数组。)在C的本机类型系统中不存在这样的实体,因此您必须自己实现它。在下文中,我将假设T
是数组中元素的类型,因为该想法与任何特定类型的内容没有任何关系。 (在您的情况下,T
为FILE *
。)
或多或少,您需要一个如下所示的结构:
struct flexarray {
T *array;
int size;
}
和一系列函数来初始化和操作这个结构。首先,让我们看一下基本访问器:
T fa_get(struct flexarray *fa, int i) { return fa->array[i]; }
void fa_set(struct flexarray *fa, int i, T p) { fa->array[i] = p; }
int fa_size(struct flexarray *fa) { return fa->size; }
请注意,为了简洁起见,这些功能不会进行任何错误检查。在现实生活中,您应该将边界检查添加到fa_get
和fa_set
。这些函数假设已flexarray
已初始化,但未显示如何执行此操作:
void fa_init(struct flexarray *fa) {
fa->array = NULL;
fa->size = 0;
}
请注意,这会将flexarray视为空。通常使这样的初始化程序创建一个固定最小大小的数组,但从零大小开始确保你运用你的数组增长代码(如下所示),并且在大多数实际情况下几乎没有任何成本。
最后,你如何让flexarray
更大?它实际上非常简单:
void fa_grow(struct flexarray *fa) {
int newsize = (fa->size + 1) * 2;
T *newarray = malloc(newsize * sizeof(T));
if (!newarray) {
// handle error
return;
}
memcpy(newaray, fa->array, fa->size * sizeof(T));
free(fa->array);
fa->array = newarray;
fa->size = newsize;
}
请注意,flexarray中的新元素未初始化,因此您应该安排在每个新索引 i 之前存储一些内容。
每次通过一些常数乘数增加弹性阵列通常是一个好主意。相反,如果你将它的大小增加一个恒定的增量,你就会花费二次时间来复制数组的元素。
我没有展示缩小数组的代码,但它与增长代码非常相似,
答案 1 :(得分:1)
任何方式它只是指针,所以你可以为它们分配内存
但不要忘记fclose()
每个文件指针,然后free()
内存