c - 将文本文件读入结构指针时出现段错误

标签 c pointers struct file-io segmentation-fault

我正在编写代码来计算 jedi 名字,它是名字和姓氏的组合。我已经编写了整个代码并在 while 循环中出现段错误。

代码如下。分为头文件和C文件:

结构.h

//void jediName(char *first_name, char *last_name, char buffer[10]);
//void jediName(struct Names Name_Param);
//void * allocate(unsigned int size);
//void * deallocate(void *, int size);

int heap_usage = 0;

struct Names{
    char *first_name;
    char *last_name;
    char *jedi_name;
};

struct Names *name;

void jediName(struct Names *Name_Param);
void * allocate(unsigned int size);
void * deallocate(void *, int size);

程序.c

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

#include "Structures.h"

int main(){

//  char fname[10];
//  char lname[10];
//  char buff[10]= "";
    char buffer1[250];
    char buffer2[250];

    FILE * fp;
/*
        printf("Enter the first & last name : \n");
        scanf("%s %s", buffer1, buffer2 );

    fp = fopen("names.txt", "a");
    fprintf(fp, "\n%s %s", buffer1, buffer2);
    fclose(fp);
*/

    fp = fopen("names.txt","r");
    name->first_name == allocate(10);
    name->last_name == allocate(10);
    name->jedi_name == allocate(10);

    while(!feof(fp)){
        fscanf(fp, "%s %s", name->first_name, name->last_name);
        jediName(name);
//      jediName(name->first_name, name->last_name, name->jedi_name);
        printf("%s %s %s", name->first_name, name->last_name);
    }
    deallocate(name->first_name, 10);
        deallocate(name->last_name, 10);
        deallocate(name->jedi_name, 10);

    fclose(fp);

    return 0;
}

/*
void jediName(char *first_name, char *last_name, char buffer[10]){
    if(strlen(first_name)<2 || strlen(last_name)<3)
        printf("Name of %s %s is too short to compute a jedi name\n", first_name, last_name);
    else{
        buffer[0] = last_name[0];
            buffer[1] = last_name[1];
            buffer[2] = last_name[2];
            buffer[3] = first_name[0];
            buffer[4] = first_name[1];
            printf("Jedi Name for %s %s is %s\n", first_name, last_name, buffer);
    }

    return;
}
*/

void jediName(struct Names *Name_Param){
        if(strlen(Name_Param->first_name)<2 || strlen(Name_Param->last_name)<3)
                printf("Name of %s %s is too short to compute a jedi name\n", Name_Param->first_name, Name_Param->last_name);
        else{
                Name_Param->jedi_name[0] = Name_Param->last_name[0];
                Name_Param->jedi_name[1] = Name_Param->last_name[1];
                Name_Param->jedi_name[2] = Name_Param->last_name[2];
                Name_Param->jedi_name[3] = Name_Param->first_name[0];
                Name_Param->jedi_name[4] = Name_Param->first_name[1];
                printf("Jedi Name for %s %s is %s\n", Name_Param->first_name, Name_Param->last_name, Name_Param->jedi_name);
        }

        return;
}

void * allocate(unsigned int size){
    heap_usage = heap_usage + size;
    printf("The current heap size after heap allocation is %d\n", heap_usage);
    void *heapMem = malloc(size);
    if(heapMem == NULL)
        printf("Pointer is NULL\n");
    else
        printf("Pointer is not NULL\n");

    return heapMem;
}

void * deallocate(void *heapMem, int size){
    heap_usage = heap_usage - size;
    printf("The current heap size after heap deallocation is %d\n", heap_usage);
    free(heapMem);
    heapMem = NULL;
    return NULL;
}

最佳答案

当您尝试取消引用 name 时,您正在调用未定义的行为,因为您没有为其分配任何空间。 name 中有一个指向任何地方的指针(我相信它实际上已初始化为 0,因为它是静态的)。在 main 中,您必须执行类似 name = malloc(sizeof *name); 的操作,或者您可以将声明更改为 struct Names name;/p>

仔细一看,name 只在main 中使用,所以在那里声明即可。不需要在更大范围内声明。

int main(void)
{
  // no point in dynamically allocating memory in this case. You don't need
  // much and you know exactly how much you need (just 1 struct)
  struct Names name;
  // but if you want to dynamically allocate it..
  // struct Names* name = malloc(sizeof *name);
  ....
  // change all your "name->" to "name." if you did not malloc
  // if you did not malloc, you must pass the address of name
  // to jediName
  // jediName(&name);

  // .. do you work

  // if you used malloc above, don't forget to free your memory
  // free(name);

  return 0;
}

另见 Why is “while ( !feof (file) )” always wrong?

关于c - 将文本文件读入结构指针时出现段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47214836/

相关文章:

c++ - 动态更改指向结构的指针数组的数据类型

c - 将结构数组传递给 C 中不同文件中的函数

C - 修改 const 结构内指针的数据

c - 在指向 char 的指针数组中输入单词时出错

c - 如何在 C 中访问链表中的下一个元素?

c - fread into array of structs 段错误

c - 为什么这段代码会导致编译错误 "redefinition"?

mysql - 使用 libmysqlclient C API 设置 collat​​ion_connection

c - 如何将 C 语言更改为外部磁盘驱动器

c - 将 sched_setaffinity 的最大 CPU 数量作为基础的正确值是多少?