fseek,fwrite,fread使用

来源:互联网 发布:淘宝 差评 后果 编辑:程序博客网 时间:2024/05/04 21:22
fseek 
 功 能:重定位流上的文件指针
 用 法:int fseek(FILE *stream, long offset, int fromwhere);
 描 述:函数设置文件指针stream的位置。如果执行成功,stream将指向以fromwhere为基准,偏移offset个字节的位置。如果执行失败(比如offset超过文件自身大小),则不改变stream指向的位置。
 返回值:成功,返回0,否则返回其他值。
 程序例:
 

点击(此处)折叠或打开

  1. 1.#include<stdio.h>

  2. 2.

  3. 3. long filesize(FILE*stream);

  4. 4. intmain(void)

  5. 5. {

  6. 6. FILE

  7. 7. *stream;

  8. 8. stream=fopen("MYFILE.TXT","w+");

  9. 9. fprintf(stream,

  10. 10. "This is a test");

  11. 11. printf("Filesize of MYFILE.TXT is %ld bytes\n",

  12. 12. filesize(stream));

  13. 13. fclose(stream);

  14. 14. return 0;

  15. 15.

  16. 16. }

  17. 17. long filesize(FILE*stream)

  18. 18. {

  19. 19. long curpos,

  20. 20. length;

  21. 21. curpos=ftell(stream);

  22. 22. fseek(stream,0L,

  23. 23. SEEK_END);

  24. 24. length=ftell(stream);

  25. 25. fseek(stream,curpos,

  26. 26. SEEK_SET);

  27. 27. returnlength;

  28. 28. }

  29. 29. intfseek(FILE

  30. 30. *stream,long offset,intorigin)

第一个参数stream为文件指针
第二个参数offset为偏移量,整数表示正向偏移,负数表示负向偏移
第三个参数origin设定从文件的哪里开始偏移,可能取值为:SEEK_CUR、 SEEK_END 或 SEEK_SET
 SEEK_SET:  文件开头
 SEEK_CUR: 当前位置
 SEEK_END: 文件结尾
 


  fread(buffer,size,count,fp);
  fwrite(buffer,size,count,fp);
  (1)buffer:是一个指针,对fread来说,它是读入数据的存放地址。对fwrite来说,是要输出数据的地址。

  (2)size:要读写的字节数;

  (3)count:要进行读写多少个size字节的数据项;

  (4)fp:文件型指针。

 注意:1 完成次写操(fwrite())作后必须关闭流(fclose());

           2 完成一次读操作(fread())后,如果没有关闭流(fclose()),则指针(FILE * fp)自动向后移动前一次读写的长度,不关闭流继续下一次读操作则接着上次的输出继续输出;

           3fprintf() : 按格式输入到流,其原型是int fprintf(FILE *stream, const char *format[, argument, ...]);其用法和printf()相同,不过不是写到控制台,而是写到流罢了。注意的是返回值为此次操作写入到文件的字节数。如int c = fprintf(fp, "%s %s %d %f", str1,str2, a, b) ;str1:10字节;str2: 10字节;a:2字节;b:8字节,c为33,因为写入时不同的数据间自动加入一个空格。

文件使用之后一定要关闭,否则将不能正确显示内容.fwrite:读入两个学生信息然后用fwrite存入文件

fread:用fread从文件中读出学生信息。

fwrite.c


点击(此处)折叠或打开

  1. #include <stdio.h>
  2.  #define SIZE 2
  3.  struct student_type
  4.  {
  5.   char name[10];
  6.   int num;
  7.   int age;
  8.   char addr[10];
  9.  }stud[SIZE];
  10.  void save()
  11.  {
  12.   FILE *fp;
  13.   int i;
  14.   if((fp=fopen("stu_list","wb"))==NULL)
  15.   {
  16.    printf("cant open the file");
  17.    exit(0);
  18.   }
  19.   for(i=0;i<SIZE;i++)
  20.   {
  21.     if(fwrite(&stud[i],sizeof(struct student_type),1,fp)!=1)
  22.      printf("file write error\n");
  23.   }
  24.   fclose(fp);
  25.  }
  26.  main()
  27.  {
  28.   int i;
  29.   for(i=0;i<SIZE;i++)
  30.   {
  31.     scanf("%s%d%d%s",&stud[i].name,&stud[i].num,&stud[i].age,&stud[i].addr);
  32.     save();
  33.   }
  34.   for(i=0;i<SIZE;i++)
  35.   {
  36.     printf("%s,%d,%d",stud[i].name,stud[i].num,stud[i].age,stud[i].addr);
  37.   }
  38. }

 

fread.c


点击(此处)折叠或打开

  1. #include <stdio.h>
  2.  #define SIZE 2
  3.  struct student_type
  4.  {
  5.   char name[10];
  6.   int num;
  7.   int age;
  8.   char addr[10];
  9.  }stud[SIZE];
  10.  void read()
  11.  {
  12.   FILE *fp;
  13.   int i;
  14.   if((fp=fopen("stu_list","rb"))==NULL)
  15.   {
  16.    printf("cant open the file");
  17.    exit(0);
  18.   }
  19.   for(i=0;i<SIZE;i++)
  20.   {
  21.     if(fread(&stud[i],sizeof(struct student_type),1,fp)!=1)
  22.      printf("file write error\n");
  23.   }
  24.   fclose(fp);
  25.  }
  26.  main()
  27.  {

  28.  int i;
  29.   read();
  30.   for(i=0;i<SIZE;i++)
  31.   {
  32.     printf("%s,%d,%d,%s",stud[i].name,stud[i].num,stud[i].age,stud[i].addr);
  33.     printf("\n");
  34.   }
  35. }

 

在C语言中进行文件操作时,我们经常用到fread()和fwrite(),用它们来对文件进行读写操作。下面详细绍一下这两个函数的用法。

  我们在用C语言编写程序时,一般使用标准文件系统,即缓冲文件系统。系统在内存中为每个正在读写的文件开辟“文件缓冲区”,在对文件进行读写时数据都经过缓冲区。要对文件进行读写,系统首先开辟一块内存区来保存文件信息,保存这些信息用的是一个结构体,将这个结构体typedef为FILE类型。我们首先要定义一个指向这个结构体的指针,当程序打开一个文件时,我们获得指向FILE结构的指针,通过这个指针,我们就可以对文件进行操作。例如:


点击(此处)折叠或打开

  1. #include <stdio.h>

  2. #include <string.h>

  3. int main()

  4. {

  5.    FILE *fp;

  6.    char buffer[100] = "This is a test";

  7.    if((fp = fopen("c:\\example.txt", "w")) == 0)

  8.     {

  9.        printf("open failed!");

  10.        exit(1);

  11.     }

  12.    fwrite(buffer, 1, strlen("This is a test"), fp);

  13.    fclose(fp);

  14.    return 0;

  15. }

 

  通过以上代码,我们就在c盘的根目录下建立了一个名为example扩展名为.txt的文件,我们打开可以看到上面写上了This is a test。当我们对它将它读出时,用如下代码:


点击(此处)折叠或打开

  1. #include <stdio.h>

  2. #include <mem.h>

  3. int main()

  4. {

  5.    FILE *fp; int len;

  6.    char buffer[100];

  7.    /*memset(buffer, 1, 100); */

  8.    if((fp = fopen("c:\\example.txt", "r")) == 0)

  9.     {

  10.        printf("open failed!");

  11.        exit(1);

  12.     }

  13.    fseek(fp, 0L, SEEK_END);

  14.    len = ftell(fp);

  15.    rewind(fp);

  16.    fread(buffer, 1, len , fp);

  17.    printf("%s",buffer);

  18.    fclose(fp);

  19.    getch();

  20.    return 0;

  21. }

 

 可以看到,当我们使用memset了以后,读出了一大堆乱码,这是为什么呢?原因是我们在fwrite函数时写入的字节数是用strlen求得的,也就是说字符串最后的'\0'并没有写到文件中去。所以我们从文件中读到buffer中时也自然没有'\0',因为buffer中的数是随机的,除非buffer中最后一个字符的下一个数恰好随机到0(可能性很小,这里用memset将它排除),否则以%s将buffer中的字符输出时遇不到0,所以乱码产生。解决的办法有很多,你可以在向文件写数据时多写入一个字节,系统会自动写入0,fwrite(buffer, 1, strlen("This is a test")+1, fp);这样读出时最后就有一个0了。或者读出操作完成后,在最后一个字符后面补上一个0:buffer[len] = 0;这样问题也可得到解决。

<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
阅读(463) | 评论(0) | 转发(0) |
0

上一篇:关于51822连接jlink的奇怪问题[已解决]

下一篇:makefile 中 $@ $^ %< 使用

相关热门文章
  • android学习--适配器和AsyncTa...
  • 黛莱美面膜怎么样?黛莱美官网...
  • 解读打车APP外包政府监管新规...
  • Redis的Append only file-续
  • gdb基本命令
  • linux 常见服务端口
  • 【ROOTFS搭建】busybox的httpd...
  • xmanager 2.0 for linux配置
  • 什么是shell
  • linux socket的bug??
  • 现在的博客积分不会更新了吗?...
  • shell怎么读取网页内容...
  • ssh等待连接的超时问题...
  • curl: (56) Recv failure: Con...
  • CACTI 不能安装WINE,怎么办?...
给主人留下些什么吧!~~
原创粉丝点击