1

当用户为朋友输入信息时,我希望指向分配的适当空间的指针,并将朋友信息存储在这个分配的空间中。我已经阅读了其他地方提到使用缓冲区数组作为scanf参数的片段,但我只是将这些放在一起。这是我到目前为止所拥有的。

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


//Structure for contacts
typedef struct friends_contact{

   char *First_Name;
   char *Last_Name;
   char *home;
   char *cell;
 }fr;

void menu(fr*friends ,int* counter,int user_entry,int i);
void setFirst(fr*,int *,int i);
char getFirst(fr*,int i);
void add_contact(fr*friends,int* counter,int i);
void print_contact(fr*friends ,int* counter, int i);

int main() 
{

  int user_entry=0;
  fr friends[5];
  int buffer[50];
  int counter=0;
  int i=0;
   for(i=0;i<5;i++)
    {
     friends[i].First_Name = (char*) malloc(sizeof(char) * 64); 
     free(friends[i].First_Name);
    }    
  menu(friends, &counter,user_entry,i);
  getch();
  return 0;
}
 //Menu function
 void menu(fr*friends,int* counter,int user_entry, int i) 
{

   do{
      int result;

      printf("\nPhone Book Application\n");
      printf("1) Add friend\n2) Delete friend\n3) Show a friend\n4)" 
      "Showonebook\n5)Exit\n");   
      scanf("%d", &user_entry);

         if(user_entry==1)
            {
            add_contact(friends,counter,i);
            }
            if(user_entry==2)
            {

            } 
            if(user_entry==3)
            {


            }                  
            if(user_entry==4)
            {
            print_contact(friends, counter,i);
            } 
       }while(user_entry!=5);                 
}

void setFirst(fr*friends, int* counter, int i) 
{
    //malloc issue **
    friends=(fr*) malloc(sizeof(fr));

    printf("Enter a first name \n");
    scanf("%s",friends[*counter].First_Name);



}
char getFirst(fr*friends , int pos) 
{

    printf("%s ", friends[pos].First_Name);
    return *friends[pos].First_Name;
}
void add_contact(fr*friends,int* counter,int i) 
{

    setFirst(friends,counter,i); 
    (*counter)++;
}
void print_contact(fr*friends ,int* counter, int i) 
{

  for( i = 0; i < *counter; i++)
    if (strlen(friends[i].First_Name))
    {
        getFirst(friends, i);
    }
 }

这显然只是代码的一部分,截至目前,我在添加名称函数中输入名称后出现分段错误。它在退出前最后一次循环到菜单。我意识到我在某个地方出了问题,我想尝试用缓冲溶液解决这个问题。解决方案有人吗?

4

1 回答 1

0

您的fr变量是指向堆栈上已分配空间的某个位置的指针。你不应该使用它 - 它已经初始化并且你不能 malloc 它(或者至少你永远不应该)。相反,您应该传递一个指针并对其进行初始化。

也就是说:

fr *friends;

然后当你想分配空间时

friends = (fr*) malloc(sizeof(fr)* NUMBER OF FR YOU WANT);

此外,如果要使用结构的元素,则需要初始化它们,因为它们都是指针。这将类似地完成

friends[i].First_Name = (char*) malloc(sizeof(char)* (LENGTH OF STRING + 1));

或者这friends[i]->First_Name取决于您如何将它发送到您的功能。

对您来说一个好的解决方案就是在您的内部初始化结构的成员main

int i;
fr friends[5];
for(i=0;i<5;i++)
{
   friends[i].First_Name = (char*) malloc(sizeof(char) * 64);
   friends[i].Last_Name = (char*) malloc(sizeof(char) * 64);
   friends[i].home = (char*) malloc(sizeof(char) * 64);
   friends[i].cell = (char*) malloc(sizeof(char) * 64);
}
//
//Do functions (without malloc'ing)
//
for(i=0;i<5;i++)
{
   free(friends[i].First_Name);
   free(friends[i].Last_Name);
   free(friends[i].home);
   free(friends[i].cell);
}

这里我选择了 64 作为字符串的长度。您可以将其设置为您认为有效的任何内容。

重要的是,您必须先为指针分配空间,然后才能使用它。否则,它不会指向您可以使用的任何内存,您将遇到分段错误。另外,不要忘记在分配完内存后释放。请记住,一旦释放它就不能使用它(除非您再次对其进行 malloc)。

于 2012-11-09T23:32:54.507 回答