我曾经使用下面的代码将一维数组写入文件:
FILE *fp;
float floatValue[5] = { 1.1F, 2.2F, 3.3F, 4.4F, 5.5F };
int i;
if((fp=fopen("test", "wb"))==NULL) {
printf("Cannot open file.\n");
}
if(fwrite(floatValue, sizeof(float), 5, fp) != 5)
printf("File write error.");
fclose(fp);
/* read the values */
if((fp=fopen("test", "rb"))==NULL) {
printf("Cannot open file.\n");
}
if(fread(floatValue, sizeof(float), 5, fp) != 5) {
if(feof(fp))
printf("Premature end of file.");
else
printf("File read error.");
}
fclose(fp);
for(i=0; i<5; i++)
printf("%f ", floatValue[i]);
我的问题是我是否要读写二维数组?
您可以使用相同的方法...只需进行以下更改
float floatValue[3][5] = {{ 1.1F, 2.2F, 3.3F, 4.4F, 5.5F },
{ 6.6F, 7.7F, 8.8F, 9.9F, 8.8F },
{ 7.7F, 6.6F, 5.5F, 4.4F, 3.3F }};
int i,j;
...
if(fwrite(floatValue, sizeof(float), 3*5, fp) != 3*5)
...
if(fread(floatValue, sizeof(float), 3*5, fp) != 3*5) {
...
for(j=0; j<3; j++) {
for(i=0; i<5; i++)
printf("%f ", floatValue[j][i]);
printf("\n");
}
当然,这不是保存/加载数据的最佳方法,特别是如果您希望在不同的编译器/系统之间甚至与将来保持某种兼容性。保存和还原的主题通常称为serialization
,并且只有很少的次要开销,因此您可以获得更大的灵活性,尤其是在数据模型变得更复杂时。
而不是单个for循环,您将添加另一个,例如:
for(i=0;i<lines;i++) {
for(j=0;j<num;j++) {
fprintf(file,"%d ",array[i][j]);
}
fprintf(file,"\n");}