2

我有这个结构

typedef struct grade
{
    char firstName[SIZE];
    char lastName[SIZE];
    int stuNum;
}GRADE;

这个输出代码:

void printData(GRADE grade[], int used)
{
    int i;
    for(i=0; i<used-1; i++)
    {
        printf("%s %s %d\n", grade[i].firstName, grade[i].lastName, grade[i].stuNum);
    }
}

当我尝试打印字符时,它们只打印字符串的第一个字符,我处于静止状态,无法真正弄清楚如何让它打印字符串的其余部分。

此代码读取数据文件(例如,格式"Firstname Lastname StudentNumber"约为 17 行"Mark Markinson 1234" newline "blah blah 1234"等)。

void readData(FILE *infile, GRADE grade[], int *count)
{
    char buf[SIZE] = {0};
    int position=*count;
    int used = 0;
    while( fgets(buf, SIZE, infile))
    { 
        removeNL(buf);

        grade[position].firstName[0] = parseName(buf, &used);
        used++;

        grade[position].lastName[0] = parseName(buf, &used);
        used++;

        grade[position].stuNum = parseNumber(buf, &used);
        used = 0;
        position++;
    }
    *count = position;

}

这是解析名称缓冲区的代码:

char parseName(char *str, int *place)
{
    char buf[SIZE] = {0}, name;
    int i=*place,j=0;

    while( str[i] != '\0' && !isspace(str[i]))
    {
        buf[j++] = str[i++];

    }
    buf[j] = '\0';

    *place = i;

    return *buf;
}

在这里采取一些建议后,我更改了一些代码,但它仍然做同样的事情(只打印第一个字符)

用这种方式调用函数

parseName(buf, &used, grade[position].firstName);

现在 parseName 是

void parseName(char *str, int *place, char *firstName)
{
    char buf[SIZE] = {0}, name;
    int i=*place,j=0;    
    while( str[i] != '\0' && !isspace(str[i]))
    {
        buf[j++] = str[i++];

    }
    buf[j] = '\0';

    *place = i;

    *firstName = *buf;
}
4

3 回答 3

3

return *buf返回(仅)buf 中的第一个字符,这是您存储到firstNameandlastName数组中的所有内容。问题是数组不是 C 中的一等类型,因此您不能将它们作为参数传递给函数或将它们作为返回值返回。

您可能想要做的是将指针传递给要填充的缓冲区parseName并让它填充它,而不是使用本地缓冲区。然后,您只需传入firstNamelastName直接传入,这将成为指向这些字段开头的指针。

于 2011-05-10T03:54:48.000 回答
1

parseName您将所有输入放入缓冲区并返回第一个字符,然后将该字符分配给firstName[0]lastName[0]永远不会对您放入缓冲区的其余数据执行任何操作。难怪只打印一个字符。

你可能应该改变你的

grade[position].firstName[0] = parseName(buf, &used);

parseName(grade[position].firstName, &used);

没有任何理由返回parseName. 您可以更改 to 的返回类型parseNamechar*返回buf而不是*buf稍微冗余(一些 C 函数这样做),这将是更好的设计。

于 2011-05-10T03:54:27.700 回答
1

问题在这里:

void readData(FILE *infile, GRADE grade[], int *count)
{
    char buf[SIZE] = {0};
    int position=*count;
    int used = 0;
    while( fgets(buf, SIZE, infile))
    { 
        removeNL(buf);

        grade[position].firstName[0] = parseName(buf, &used);
        used++;

        grade[position].lastName[0] = parseName(buf, &used);
        used++;

        grade[position].stuNum = parseNumber(buf, &used);
        used = 0;
        position++;
    }
    *count = position;

}

当您调用 parseName 时,您只需设置第一个字符。您应该将数组(将在其中写入字符串)传递给 parseName:

void readData(FILE *infile, GRADE grade[], int *count)
{
    char buf[SIZE] = {0};
    int position=*count;
    int used = 0;
    while( fgets(buf, SIZE, infile))
    { 
        removeNL(buf);

        parseName(buf, &used, grade[position].firstName);
        used++;

        parseName(buf, &used, grade[position].lastName);
        used++;

        grade[position].stuNum = parseNumber(buf, &used);
        used = 0;
        position++;
    }
    *count = position;

}

不要忘记更改 parseName 添加参数并将结果写入其中。

于 2011-05-10T03:57:28.153 回答