繁体   English   中英

初始化结构后,为什么结构的值损坏了?

[英]Why are the values of a struct corrupted after the struct is initialized?

我正在尝试使用一些值初始化结构数组,但是我无法使这些值保持恒定。 我使用一个初始的for循环从字符串中检索值,并将其分配给数组中的结构。 一旦尝试使用另一个循环迭代该数组,某些值将不相同。

这是有问题的代码:

    void printOrder(Order *node)
    {
         printf("Title is: %s\n",node->title);
         printf("Price is: $%f\n",node->price);
         printf("ID is: %d\n",node->custID);
         printf("Category is: %s\n",node->category);
    }

    void initOrder(Order *newOrder, char *title, double price, int custID, char   *category)
    {
         newOrder->title = title;
         newOrder->price = price;
         newOrder->custID = custID;
         newOrder->category = category;
         newOrder->next = NULL;

         printf("new order object initialized\n");
    }

    char *title;
    char *priceTemp;
    char *idTemp;
    char *category;

    Order localOrders[numOrders]; // numOrders is a value found earlier

    int k;
    for(k = 0; k < numOrders; k++)
    {

            fgets(Line,orderLineSize,orders); // orderLineSize was found earlier


            title = strtok(Line,"|");
            priceTemp = strtok(NULL,"|");
            idTemp = strtok(NULL,"|");
            category = strtok(NULL,"|");

            price = atof(priceTemp);
            id = atoi(idTemp);

            localOrders[k].title = title;
            localOrders[k].price = price;
            localOrders[k].custID = id;
            localOrders[k].category = category;

            Order *temp = &localOrders[k];

            initOrder(temp,title,price,id,category);
            printOrder(temp);
    }
    Order *temp;

    for(k = 0; k < numOrders; k++)
    {
            temp = &localOrders[k];
            printOrder(temp);
            printf("\n");
    }

这是Order的头文件:

#ifndef ORDER_H
#define ORDER_H
#include <stdlib.h>
struct Order {
    char *title;
    double price;
    int custID;
    char *category;

    struct Order *next;
};

typedef struct Order Order;

void initOrder(Order *newOrder, char *title, double price, int custID, char *category);
void printOrder(Order *node);

#endif

例如,第一个循环将打印:

Title is: "Tasting Beer: An Insider's Guide to the World's Greatest Drink"
Price is: $11.310000
ID is: 5
Category is: HOUSING01

第二个循环会给我什么:

Title is: "Tasting Beer: An Insider's Guide to the World's Greatest Drink"
Price is: $19.800000
ID is: 2
Category is: s Guide to the World's Greatest Drink"

为什么在第一个循环中初始化结构的值在第二个循环中被覆盖? 标题似乎并没有受到影响,但是其余参数一直被覆盖,我不确定为什么。

strtok()将指针返回到字符缓冲区Line ,该缓冲区稍后在下次调用fgets()时被覆盖。

要保存标记化字符串的“组件”,例如,可以使用strdup()复制字符串:

title = strdup(strtok(Line,"|"));
// ...

您需要为每个数据元素分配内存。 您正在做的事情是为字符串使用相同的存储区,只记住指向这些区域的指针,而不是为每个字符串使用新的存储区。

因此,您需要为读入的每个记录malloc()一个新的存储区,以便每个记录都有其自己的唯一存储区,而不是所有共享相同存储区的记录。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM