c - 将文件字符串转换为字符指针

标签 c file pointers struct

你好,首先我会提供一些细节,我正在工作:

Ubuntu,c语言,我的编译器是gcc。

我正在对我的技能进行 lisle 测试,因为我不太擅长指针,所以我试试运气,但得到了一个奇怪的输出。

我现在将展示我的代码。

  #include<stdio.h>
  #include<string.h>
  #define F1 ".file.txt"
  typedef struct{
   char par1[30];
   int par2;
   int par3;
   int par4;
   char* par5[3];
  }S1;
 //this was the structure I was working


  void initiate_S1(S1*a,char part1[],int* part2,int *part3, int*part4,char part51[],char part52[],char part53[]);
  //this function will start the struct parameters 
  void get_S1(S1*a);
  //this function will print struct parameters

  void save_S1_on_file(S1*a);
  //this will save all parameters of a structure in file

  void search_S1_on_file(S1*a);
  //This function will search for a first parameter of structure and if
 //find it fill the other parameters


  int main(){
   S1 a;
   int part2,part3,part4;
   char part1[30],part51[15],part52[15],part53[15];

   scanf("%s %d %d %d %s %s %s",part1,&part2,&part3,&part4,part51,part52,part53);

   initiate_S1(&a,part1,&part2,&part3,&part4,part51,part52,part53);

   get_S1(&a);

   save_S1_on_file(&a);

   search_S1_on_file(&a);

   get_S1(&a);

   return 0;
   }
   //this main is only to test the functions

   void initiate_S1(S1*a,char part1[],int* part2,int *part3, int*part4,char part51[],char part52[],char part53[]){

    strcpy(a->par1,part1);
    a->par2=*part2;
    a->par3=*part3;
    a->par4=*part4;
    a->par5[0]=part51;
    a->par5[1]=part52;
    a->par5[2]=part53;
   }

   void get_S1(S1*a){
    printf("%s\n%d\n%d\n%d\n%s %s %s\n",a->par1,a->par2,a->par3,a->par4,a->par5[0],a->par5[1],a->par5[2]);
   }

   void save_S1_on_file(S1*a){

     FILE *af;
     af=fopen(F1,"a");
     fprintf(af,"%s;%d;%d;%d;%s;%s;%s;\n",a->par1,a->par2,a->par3,a->par4,a->par5[0],a->par5[1],a->par5[2]);
     fclose(af);
   }

   void search_S1_on_file(S1*a){
    FILE *af;
    char s[100];
    char*token;
    af=fopen(F1,"r");
    int n=2;
    while(fgets(s,100,af)!=NULL){
     token=strtok(s,";");
     if(strstr(a->par1,token)!=NULL){
      n=0;
      token=strtok(NULL,";");
      a->par2=atoi(token);
      token=strtok(NULL,";");
      a->par3=atoi(token);
      token=strtok(NULL,";");
      a->par4=atoi(token);
      a->par5[0]=strtok(NULL,";");
      a->par5[1]=strtok(NULL,";");
      a->par5[2]=strtok(NULL,";");
      break;
     }
     else
      n=1;
    }
    if(n==1)
     printf("The S1 no exist\n");
   }

输入:

 name 15 3 2 tag1 tag2 tag3

输出:

    name
    15
    3  
    2
    tag1 tag2 tag3
    name
    15
    3
    2
    %��j��2 j��2 tag3

出于某种原因,当我尝试从文件字符串中填充字符指针时,出现了这个奇怪的输出 为什么会出现这个奇怪的字符,我的代码有什么问题?

最佳答案

在你调用 search_S1_on_file() 之前你很好

在指针数组 a->par5 中,您分配局部变量 s 的地址。

  a->par5[0]=strtok(NULL,";");/* The string being broken into tokens is a local array */
  a->par5[1]=strtok(NULL,";");
  a->par5[2]=strtok(NULL,";");

一旦您退出此函数,分配给数组 s 的内存将被释放,因此访问此内存位置您一定会得到垃圾值,因为这是 UB。

为了解决这个问题,在 main 中保留一个 char array 并将其与其他 requierd 参数一起传递给函数 search_S1_on_file(),这应该可以工作。

或者,您可以尝试在堆上为数组 s 分配内存,例如

char *s = malloc(100); /* Take care to free this memory accordingly */

关于c - 将文件字符串转换为字符指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28021940/

相关文章:

c - C 中的字节顺序和指针转换

c - 像这样在函数调用中分配的内存会发生什么变化?

file - 编辑平面文件以在每行上包含特定数量的字符?

file - 如何在 Clojure 中从文件中读取多个变量?

c - 尝试读取隐藏文件 linux 时出现段错误

c - C语言浮点除法

c - 是否需要关闭 systemv 消息队列

python - 明确关闭文件重要吗?

c++ - 为什么将指针转换为引用在我的访问器 (getter) 中不起作用?

c++ - 为什么在 C++ 中将值插入类时出现运行时错误