xiaoniugogogo 发表于 2024-9-9 15:50:51

C求助

求助大佬,为什么这段代码里book_w->date.day=26赋值26会有问题,别的值不会。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
struct Date
{
    int year;
    int month;
    int day;
};
struct Book
{
    char title;
    float price;
    struct Date date;

};
int main(void)
{
    struct Book *book_w,*book_r;
    FILE *fp;
    //分配内存
    book_w=(struct Book *)malloc(sizeof(struct Book));
    book_r=(struct Book *)malloc(sizeof(struct Book));
   
    if ( book_r==NULL||book_w==NULL)
    {
      printf("error");
      exit(1);
    }
    //结构体赋值
    strcpy(book_w->title,"xiyouji");
    book_w->price=29.9;
    book_w->date.year=1999,book_w->date.month=9,book_w->date.day=26;
    //
    if ( ( fp=fopen("F:/9.9.txt","w") ) ==NULL )
    {   printf("error");
      exit(1);
    }
    //写入
    fwrite(book_w,sizeof(struct Book),1,fp);
    fclose(fp);
    //
    if ( ( fp=fopen("F:/9.9.txt","r") ) ==NULL )
    {   printf("error");
      exit(1);
    }
   
    fread(book_r,sizeof(struct Book),1,fp);
    //
    printf("title: %s\n",book_r->title);
    printf("price: %.2f\n",book_r->price);
    printf("date: %d-%d-%d\n",book_r->date.year,book_r->date.month,book_r->date.day);
    //
    fclose(fp);
    free(book_r);
    free(book_w);
    return 0;
}

FishC 发表于 2024-9-9 16:02:59

这段代码中的问题与`book_w->title`的定义和使用有关。

首先,代码中定义的`struct Book`结构体的`title`成员为`char`类型,而不是`char[]`或`char*`,这会导致后面使用`strcpy(book_w->title,"xiyouji");`时出现问题。

具体来说:

1. **错误的定义:**
   struct Book
   {
       char title;
       float price;
       struct Date date;
   };
   这里的`title`仅仅是一个字符,而不是一个字符串。如果你想存储书名(一个字符串),`title`应该定义为字符数组或者指针,例如:
   struct Book
   {
       char title;// 假设书名最长为50个字符
       float price;
       struct Date date;
   };
   或者:
   struct Book
   {
       char *title;// 指向一个字符串
       float price;
       struct Date date;
   };

2. **内存问题:**
   如果你使用字符指针`char *title`,需要为`title`分配内存,比如通过`malloc`:
   book_w->title = (char *)malloc(50 * sizeof(char));// 分配50个字符的空间

3. **`book_w->date.day=26`赋值问题:**
   `book_w->date.day=26` 赋值的问题很可能是由于内存错误引发的。当你错误地处理`title`时,后续内存操作可能会导致其他字段(如`date.day`)受到影响。

### 修复后的代码:

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

struct Date
{
    int year;
    int month;
    int day;
};

struct Book
{
    char title;// 修改为字符数组
    float price;
    struct Date date;
};

int main(void)
{
    struct Book *book_w, *book_r;
    FILE *fp;
   
    // 分配内存
    book_w = (struct Book *)malloc(sizeof(struct Book));
    book_r = (struct Book *)malloc(sizeof(struct Book));
   
    if (book_r == NULL || book_w == NULL)
    {
      printf("error");
      exit(1);
    }

    // 结构体赋值
    strcpy(book_w->title, "xiyouji");// 正确的字符串赋值
    book_w->price = 29.9;
    book_w->date.year = 1999;
    book_w->date.month = 9;
    book_w->date.day = 26;

    // 打开文件写入
    if ((fp = fopen("F:/9.9.txt", "w")) == NULL)
    {
      printf("error");
      exit(1);
    }

    fwrite(book_w, sizeof(struct Book), 1, fp);
    fclose(fp);

    // 打开文件读取
    if ((fp = fopen("F:/9.9.txt", "r")) == NULL)
    {
      printf("error");
      exit(1);
    }

    fread(book_r, sizeof(struct Book), 1, fp);

    // 打印读取的数据
    printf("title: %s\n", book_r->title);
    printf("price: %.2f\n", book_r->price);
    printf("date: %d-%d-%d\n", book_r->date.year, book_r->date.month, book_r->date.day);

    fclose(fp);
    free(book_r);
    free(book_w);

    return 0;
}

### 关键修正点:
1. 将`title`修改为`char title;`以存储字符串。
2. 使用`strcpy`时可以安全地将字符串复制到`title`数组中。
3. 由于标题问题修复,赋值`book_w->date.day=26`将不再引发问题。

这种修改确保了内存的正确使用,避免了潜在的越界写入问题。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

很cool的阳 发表于 2024-9-9 16:08:21

1. **文件路径问题**:确保 `"F:/9.9.txt"` 这个路径在你的系统中是有效的,并且程序有足够的权限在该路径下创建和写入文件。

2. **内存分配失败**:虽然你检查了 `book_r` 和 `book_w` 是否为 `NULL`,但是如果在 `malloc` 调用之后立即检查,可能会错过一些在赋值操作中导致的问题。确保在每次使用指针之前都检查它是否为 `NULL`。

3. **结构体对齐**:在某些编译器或系统上,结构体可能会因为内存对齐的原因而占用比实际成员大小更多的空间。这通常不会影响基本的赋值操作,但如果你的系统对齐要求非常严格,可能会导致问题。

4. **文件读写模式**:你使用了 `"w"` 模式打开文件进行写操作,这会创建新文件或覆盖现有文件。然后你使用 `"r"` 模式打开文件进行读操作。确保在尝试读取文件之前,文件已经被正确写入。

5. **数据类型和精度问题**:你的代码中使用了 `float` 类型来存储价格,这可能会导致精度问题,尤其是在文件读写时。确保你的程序能够正确处理浮点数的读写。

6. **编译器或环境问题**:不同的编译器或开发环境可能会以不同的方式处理内存和文件操作。尝试在不同的编译器或环境中运行你的代码,看看是否仍然存在问题。

xiaoniugogogo 发表于 2024-9-9 16:09:32

FishC 发表于 2024-9-9 16:02
这段代码中的问题与`book_w->title`的定义和使用有关。

首先,代码中定义的`struct Book`结构体的`title ...

我定义的title本来就是长度20的数组啊,而且用你给的代码运行也是错误的

FishC 发表于 2024-9-9 16:09:48

xiaoniugogogo 发表于 2024-09-09 16:09
我定义的title本来就是长度20的数组啊,而且用你给的 ...

抱歉,刚才的回答忽略了你提到的`title`是长度为20的字符数组的问题。既然你提到`title`的定义是长度为20的字符数组,我们可以进一步分析和修改你的代码。

首先,回顾一下代码中的主要问题:

### 1. `title` 定义的问题
你提到`title`的定义是长度为20的字符数组,但我没有看到这部分定义在你提供的代码中。正确的定义应该是:

```c
struct Book {
    char title; // title 是一个可以存储

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: [1]
查看完整版本: C求助