2012-02-11 76 views
4

我试图编写一个程序,将结构元素写入二进制文件,然后将第一个文件中的唯一元素写入另一个二进制文件。我编译它与海湾合作委员会,它的工作非常好,但与MinGW程序冻结,当它试图打开并创建第二个文件。你知道问题在哪里吗?C中的可移植性问题

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

typedef struct element{ 
    char name[80]; 
    int p; 
}ELEM; 

void clear_stdin() 
{ 
    char str[255]; 
    fgets(str,255,stdin); 
} 

int create() 
{ 
    FILE *f; 
    int d=0; 
    int c; 
    int n=0; 
    ELEM s; 
    f=fopen("file.bin","wb"); 
    if(f==NULL) 
    { 
     printf("create(): Could not open file.bin for read\n"); 
     return; 
    } 
    do{ 
    printf("Add elements to file?:\n1 - yes\n2 - no\n"); 
    scanf("%d",&c); 
    if (c==1) 
    { 
     printf("Name="); 
     clear_stdin(); 
     fgets(s.name,80,stdin); 
     printf("P="); 
     scanf("%d",&s.p); 
     fwrite(&s,sizeof(ELEM),1,f); 
     n++; 
    } 
    else 
     d=1; 
    } while(d==0); 
    fclose(f); 
    return n; 
} 

void show(int n) 
{ 
    FILE *f; 
    ELEM s; 
    int i=0; 
    if(n==0) 
     return; 
    f=fopen("file.bin","rb"); 
    while(i<n) 
    { 
     fread(&s,sizeof(ELEM),1,f); 
     puts(s.name); 
     printf("\t%d\n",s.p); 
     i++; 
    } 
    fclose(f); 
} 

int add(int n) 
{ 
    FILE *f; 
    int d=0; 
    int c; 
    ELEM s; 
    f=fopen("file.bin","ab"); 
    if(f==NULL) 
    { 
     printf("add(): Could not open file.bin for append\n"); 
     return; 
    } 
    do{ 
    printf("Add elements to file?:\n1 - yes\n2 - no\n"); 
    scanf("%d",&c); 
    if (c==1) 
    { 
     printf("Name="); 
     clear_stdin(); 
     fgets(s.name,80,stdin); 
     printf("P="); 
     scanf("%d",&s.p); 
     fwrite(&s,sizeof(ELEM),1,f); 
     n++; 
    } 
    else 
     d=1; 
    } while(d==0); 
    fclose(f); 
    return n; 
} 


void func(int n) 
{ 
    FILE *f,*g; 
    ELEM v[20],w; 
    int i=0,j,k,x=0,s,gn=0,test; 
    f=fopen("file.bin","rb"); 
    g=fopen("aux.bin","wb"); 
    if((g==NULL)||(f==NULL)) 
    { 
     if(g==NULL) 
      printf("function() : Could not open aux.bin for write\n"); 
     if(f==NULL) 
      printf("function() : Could not open file.bin for read\n"); 
     return; 
    } 
    i=0; 
    while(i<n) 
    { 
     fread(&v[i],sizeof(ELEM),1,f); 

     i++; 
    } 
    for(j=0;j<n;j++) 
    { 
     for(k=j+1;k<n;k++) 
     { 
      if(v[j].p==v[k].p) 
       x=1; 

     } 
     if(x==0) 
     { 
      s=strcmp(v[j].name,v[k].name); 
      if(s!=0) 
      { 
       fwrite(&v[j],sizeof(ELEM),1,g); 
       fread(&w,sizeof(ELEM),1,g); 

       gn++; 
      } 
     } 
     x=0; 
    } 
    test=fclose(g); 
    if(test!=0) 
     printf("function() : failed to closed file g\n"); 
    test=fclose(f); 
    if(test!=0) 
     printf("function() : failed to closed file f\n"); 
    g=fopen("aux.bin","rb"); 
    if(g==NULL) 
    { 
     printf("function() : Could not open aux.bin for read\n"); 
     return; 
    } 
    if(gn==0) 
     return; 
    i=0; 
    while(i<gn) 
    { 
     fread(&w,sizeof(ELEM),1,g); 
     puts(w.name); 
     printf("\t%d\n",w.p); 
     i++; 
    } 
    fclose(g); 
} 

int main() 
{ 
    int k=0,r,n; 
    do{ 
     printf("1 - create file\n2 - add elements to file\n3 - show elements\n4 - put unique elements in another file\n5 - exit program\n"); 
     scanf("%d",&r); 
     switch(r) 
     { 
      case 1 : n=create(); break; 
      case 2 : n=add(n); break; 
      case 3 : show(n); break; 
      case 4 : func(n); break; 
      case 5 : k=1; break; 
      default : printf("Command unrecognized!\n"); 
     } 
    } while(k==0); 
    return 0; 
} 

编辑: 功能FUNC()是唯一的问题。

编辑:是的,我可以在gdb下运行它。

编辑: 在两种情况下,sizeof(ELEM)= 84 offsetof(ELEM,p)= 80。

+3

你可以缩短代码吗?要求某人阅读很多东西。 – StilesCrisis 2012-02-11 18:13:52

+1

您需要制作一个简单的示例,最好是非交互式的,以显示问题。很有可能,在你有一个值得在这里发表的例子之前,你会弄清楚发生了什么。 – 2012-02-11 18:15:58

+0

今天每半个小时,结构序列化问题如何出现? – 2012-02-11 18:21:15

回答

3

哇,你不会猜这个:aux.bin,实际上任何东西aux.*是在Windows上保留的文件名!这就是为什么它要永远!看看这里,所以你不小心选择另一个保留的文件名: windows file name specification(搜索'aux'的页面)

+0

谢谢!它现在有效! – user1089723 2012-02-11 19:06:24

+0

这对于CON,LPT1等也是如此。几年前,在生产系统中发现了困难。 – Joe 2012-02-11 19:34:40