如何从C中的动态数组中读取二进制文件中的数据

时间:2013-01-14 11:01:18

标签: c arrays dynamic data-structures binaryfiles

在下面的代码中,我尝试从二进制文件中读取数据并将其写入动态数组。
函数“getAnz”应该给我数据集的数量。
在函数“readRecs”中,我想从二进制文件中读取数据并将其写入动态数组(zArr)。
该程序为我提供了正确数量的数据集。呀。

现在我几乎没有问题:
1.我读取数据并将其写入动态数组的方式有什么问题?
2.如何将“zArr”从main函数传递给readRecs函数?
3.是否有另一种更简单的方法来获取文件中的数据集数量?
谢谢你的帮助。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

struct daten
{
    char name[20];
    int alter;
};

long getAnz(FILE *fp)
{
    struct daten ptr;
    long counter = 0;

    while(fread(&ptr, sizeof(struct daten), 1, fp))
    {
        counter++;
    }

    fclose(fp);

    return counter;
}

void foo(FILE *fp, struct daten *zArr[], long lAnz)
{
    long i = 0;

    for(i = 0;i < lAnz;i++)
    {
        if(i == 0)
        {
             zArr = malloc(sizeof(*zArr));
        }
        else
        {
            zArr = realloc(zArr,sizeof(*zArr)*(i+1));
        }   
    }

    fclose(fp);
}

int main(void)
{
    struct daten *zArr;
    long anz = 0, i = 0;

    FILE *fp = fopen("daten.bin", "rb");
    anz = getAnz(fp);
    printf("%ld\n", anz);
    foo(fp, &zArr, anz);

    for(i = 0; i<anz; i++)
    {
        printf("%s\t", zArr[i].name);
        printf("%d\n", zArr[i].alter);
    }

    return 0;
}

2 个答案:

答案 0 :(得分:0)

在您传递的其他问题中,指针zArr的值为void foo(FILE *fp, struct daten *zArr[], long lAnz),因此其更改的范围在函数内。如果你希望在foo返回后保持更改,请尝试void foo(FILE *fp, struct daten * &zArr, long lAnz)

答案 1 :(得分:0)

Here我做了动态阅读:

ssize_t mygetline(char **buffer, int fd){
        size_t bufportion = 16000, bufsz = bufportion, i = 0;
        free(*buffer); *buffer = NULL;
        char *ptr;
        char *buf;
        buf = malloc(bufsz);
        if(!buf){freeQS(); die(MEMERR);}
        ptr = buf;
        if(read(fd, ptr, 1) != 1){ free(buf); return -1; }
        do{
                if(*ptr == '\n' || *ptr == 0) break;
                ptr++;
                if(++i >= bufsz){
                        bufsz += bufportion;
                        buf = realloc(buf, bufsz);
                        if(!buf){freeQS(); die(MEMERR);}
                        ptr = &buf[i];
                }
        }while(read(fd, ptr, 1) == 1);
        *ptr = 0;
        if(ptr > buf && *(ptr-1) == '\r') *(ptr-1) = 0;
        *buffer = strdup(buf);
        free(buf);
        return strlen(*buffer);
}

在上面的代码中,没有用数据填充数组的操作。