fopen()、fwrite()、fread()函数使用说明与示例

fopen()函数:

1.作用: 在C语言中fopen()函数用于打开指定路径的文件,获取指向该文件的指针。

2.函数原型:

[cpp] view plain copy

  1. FILE * fopen(const char * path,const char * mode);
  2. -- path: 文件路径,如:"F:\Visual Stdio 2012\test.txt"
  3. -- mode: 文件打开方式,例如:
  4. "r" 以只读方式打开文件,该文件必须存在。
  5. "w" 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
  6. "w+" 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
  7. "a" 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
  8. "a+" 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。(原来的EOF符不保留)
  9. "wb" 只写打开或新建一个二进制文件,只允许写数据。
  10. "wb+" 读写打开或建立一个二进制文件,允许读和写。
  11. "ab" 追加打开一个二进制文件,并在文件末尾写数据。
  12. "ab+"读写打开一个二进制文件,允许读,或在文件末追加数据。
  13. --返回值: 文件顺利打开后,指向该流的文件指针就会被返回。如果文件打开失败则返回NULL,并把错误代码存在errno中。

fwrite()函数:

1.作用:在c语言中fwrite()函数常用语将一块内存区域中的数据写入到本地文本。

2.函数原型:

[cpp] view plain copy

  1. size_t fwrite(const void* buffer, size_t size, size_t count, FILE* stream);
  2. -- buffer:指向数据块的指针
  3. -- size:每个数据的大小,单位为Byte(例如:sizeof(int)就是4)
  4. -- count:数据个数
  5. -- stream:文件指针

注意:返回值随着调用格式的不同而不同:

(1) 调用格式:fwrite(buf,sizeof(buf),1,fp);

成功写入返回值为1(即count)

(2)调用格式:fwrite(buf,1,sizeof(buf),fp);

成功写入则返回实际写入的数据个数(单位为Byte)

[cpp] view plain copy

3. 注意事项:

写完数据后要调用fclose()关闭流,不关闭流的情况下,每次读或写数据后,文件指针都会指向下一个待写或者读数据位置的指针。

示例说明:

代码1:下面代码可将1024个字(int)写入到文本文件,fwrite的调用中,size是sizeof(int),count是DATA_SIZE

[cpp] view plain copy

  1. #include "stdafx.h"
  2. #define _CRT_SECURE_NO_WARNINGS
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5. #define DATA_SIZE 1024
  6. int main()
  7. {
  8. unsigned int *dataPtr = NULL;
  9. dataPtr = (unsigned int *)malloc(sizeof(int)*DATA_SIZE);
  10. for(unsigned int i=0;i<DATA_SIZE;i++)
  11. {
  12. dataPtr[i] = i; //初始化缓存区
  13. }
  14. FILE *fp = fopen("F:\\Labwindows cvi\\test.txt","w");
  15. fwrite(dataPtr,sizeof(int),DATA_SIZE,fp);
  16. fclose(fp);
  17. free(dataPtr);
  18. system("pause");
  19. return 0;
  20. }

代码2:下面代码也可将1024个字写到文本中,虽然fwrite函数中,size是1,但count是DATA_SIZE*sizeof(int)。与代码1实现的结果一样。

[cpp] view plain copy

  1. // datasave.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #define _CRT_SECURE_NO_WARNINGS
  5. #include <stdio.h>
  6. #include <stdlib.h>
  7. #define DATA_SIZE 1024
  8. int main()
  9. {
  10. unsigned int *dataPtr = NULL;
  11. dataPtr = (unsigned int *)malloc(sizeof(int)*DATA_SIZE);
  12. for(unsigned int i=0;i<DATA_SIZE;i++)
  13. {
  14. dataPtr[i] = i; //初始化缓存区
  15. }
  16. FILE *fp = fopen("F:\\Labwindows cvi\\test.txt","ab+");
  17. fwrite(dataPtr,1,DATA_SIZE*sizeof(unsigned int),fp);
  18. <pre name="code" class="cpp">       fclose(fp);
  19. <pre name="code" class="cpp">       free(dataPtr);

system("pause");    return 0;}


代码3:下面的代码将4096个char数据写到文本,写入的数据中,最大值为255,与上面代码1、2有区别,因为缓存区数据类型不同

[cpp] view plain copy

  1. // datasave.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #define _CRT_SECURE_NO_WARNINGS
  5. #include <stdio.h>
  6. #include <stdlib.h>
  7. #define DATA_SIZE 1024
  8. int main()
  9. {
  10. unsigned char *dataPtr = NULL;
  11. dataPtr = (unsigned char *)malloc(sizeof(int)*DATA_SIZE); //申请的区域是4096个char,即1024个字的区域
  12. for(unsigned int i=0;i<DATA_SIZE;i++)
  13. {
  14. dataPtr[i] = i; //初始化缓存区
  15. }
  16. FILE *fp = fopen("F:\\Labwindows cvi\\test.txt","ab+");
  17. fwrite(dataPtr,sizeof(char),DATA_SIZE*sizeof(int),fp);
  18. fclose(fp);
  19. free(dataPtr);
  20. system("pause");
  21. return 0;
  22. }

代码4:用malloc函数申请区域时是申请的一片char*区域,通过强制类型转换后可装unsigned int 数据。

[cpp] view plain copy

  1. // datasave.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #define _CRT_SECURE_NO_WARNINGS
  5. #include <stdio.h>
  6. #include <stdlib.h>
  7. #define DATA_SIZE 1024
  8. int main()
  9. {
  10. unsigned char *dataPtr = NULL;
  11. unsigned int *Ptr = NULL;
  12. dataPtr = (unsigned char *)malloc(sizeof(int)*DATA_SIZE);
  13. Ptr = (unsigned int *) dataPtr;
  14. for(unsigned int i=0;i<DATA_SIZE;i++)
  15. {
  16. Ptr[i] = i;
  17. }
  18. FILE *fp = fopen("F:\\Labwindows cvi\\test.txt","ab+");
  19. fwrite(Ptr,sizeof(unsigned int),DATA_SIZE,fp);
  20. fclose(fp);
  21. free(dataPtr);
  22. system("pause");
  23. return 0;
  24. }

fread()函数:
1. 作用:从一个文件流中读取数据
2. 函数原型如下:

[cpp] view plain copy

  1. size_t fread(void *buffer, size_t size, size_t count, FILE *stream);
  2. -- buffer:指向数据块的指针
  3. -- size:每个数据的大小,单位为Byte(例如:sizeof(int)就是4)
  4. -- count:数据个数
  5. -- stream:文件指针

注意:返回值随着调用格式的不同而不同:
(1) 调用格式:fread(buf,sizeof(buf),1,fp);
读取成功时:当读取的数据量正好是sizeof(buf)个Byte时,返回值为1(即count)
                       否则返回值为0(读取数据量小于sizeof(buf))
(2)调用格式:fread(buf,1,sizeof(buf),fp);
读取成功返回值为实际读回的数据个数(单位为Byte)

代码参考:

[cpp] view plain copy

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. int main(int argc, char *argv[])
  5. {
  6. FILE *filp = NULL;
  7. char fileDir[] = "/home/yangzhiyuan/Documents/test.txt";
  8. char dataPtr[] = "Helloworld";
  9. printf("sizeof(dataPtr) = %ld\n",sizeof(dataPtr));
  10. filp = fopen(fileDir,"w+");  /* 可读可写,不存在则创建 */
  11. int writeCnt = fwrite(dataPtr,sizeof(dataPtr),1,filp);  /* 返回值为1 */
  12. //int writeCnt = fwrite(dataPtr,1,sizeof(dataPtr),filp);  /* 返回值为11 */
  13. printf("writeCnt = %d\n",writeCnt);
  14. fclose(filp);
  15. FILE *fp = NULL;
  16. fp = fopen(fileDir,"r");
  17. char buffer[256];
  18. int readCnt = fread(buffer,sizeof(buffer),1,fp);  /* 返回值为0 */
  19. //int readCnt = fread(buffer,1,sizeof(buffer),fp);  /* 返回值为11 */
  20. printf("readCnt = %d\n",readCnt);
  21. fclose(fp);
  22. printf("%s\n",buffer);
  23. exit(0);
  24. }

注意:本例代码中定义了两个FILE变量,一个用于write,一个用于read,写完后要close掉,然后再打开,然后读。如果直接使用一个FILE变量,会出错!

时间: 2024-11-08 20:45:04

fopen()、fwrite()、fread()函数使用说明与示例的相关文章

open()、fwrite()、fread()函数使用说明与示例

fopen()函数: 1.作用: 在C语言中fopen()函数用于打开指定路径的文件,获取指向该文件的指针. 2.函数原型: FILE * fopen(const char * path,const char * mode); -- path: 文件路径,如:"F:\Visual Stdio 2012\test.txt" -- mode: 文件打开方式,例如: "r" 以只读方式打开文件,该文件必须存在. "w" 打开只写文件,若文件存在则文件长

Linux 打开文件并写入一段字符串,同时读出对应文件的信息--fopen()/fwrite()/fread()

Linux 打开文件并写入一段字符串,同时读出对应文件的信息 在Linux中,采用C语言,使用fopen()函数打开一个文件(若不存在文件,则新建一个 如 data/test.dat),同时采用 fwrite()向其中写入相应的字符串,每次输入写入都换行,最后采用fread()读出相应的信息. 相应的代码如下:Test.c /* Test.c :create a file : Write a string to the file */ #include <stdio.h> #include &

Linux 打开文件并写入一段字符串,同一时候读出相应文件的信息--fopen()/fwrite()/fread()

Linux 打开文件并写入一段字符串.同一时候读出相应文件的信息 在Linux中.採用C语言.使用fopen()函数打开一个文件(若不存在文件,则新建一个 如 data/test.dat),同一时候採用 fwrite()向当中写入对应的字符串,每次输入写入都换行,最后採用fread()读出对应的信息. 对应的代码例如以下:Test.c /* Test.c :create a file : Write a string to the file */ #include <stdio.h> #inc

(转载)C++文件读写函数之——fopen、fread和fwrite、fgetc和fputc、fgets和fputs、ftellf和fseek、rewind

http://blog.sina.com.cn/s/blog_61437b3b0102v0bt.html http://blog.csdn.net/chenwk891/article/details/8776479 在C\C++中,文件操作都是由库函数来实现的,主要是分为读和写两种操作,以下详细讲解以下所有有关文件操作的用法: (1)fopen()函数:打开文件 包含头文件:#include 格式:FILE * fopen(const char * path,const char * mode)

fscanf函数和fprintf函数、fgets函数和fputs函数、fread函数和fwrite函数

1. fscanf 函数和 fprintf 函数 1.1 fscanf 函数 fscanf 函数只能从文本文件中按格式输入.fscanf 函数和 scanf 函数相似,只是输入的对象是磁盘上文本文件的数据.函数的调用形式如下: fscanf( 文件指针,格式控制字符串,输入项表 ); 例如,若文件指针 fp 指向一个已打开的文本文件,a.b 分别为整型变量,则以下语句从 fp 所指的文件中读入两个整数放入变量 a 和 b 中: fscanf( fp, "%d%d", &a, &

fread函数

收藏 查看我的收藏 719有用+1 已投票 4 fread 编辑 锁定 fread是一个函数.从一个文件流中读数据,最多读取count个项,每个项size个字节,如果调用成功返回实际读取到的项个数(小于或等于count),如果不成功或读到文件末尾返回 0. 中文名 无 外文名 fread 属    性 函数 参    数 buffer 函数原型 size_t fread 所属库 #include <stdio.h> 目录 1 简介 ? 函数原型 ? 参 数 ? 返回值 2 程序例 ? C语言

FILE文件流的中fopen、fread、fseek、fclose的使用

FILE文件流用于对文件的快速操作,主要的操作函数有fopen.fseek.fread.fclose,在对文件结构比较清楚时使用这几个函数会比较快捷的得到文件中具体位置的数据,提取对我们有用的信息,满足编程中的需要.以下分别进行说明,还有他们使用时的注意事项 fopen 函数原型    FILE * fopen(const char *path,cost char *mode) 作用:打开一个文件,返回指向该文件的指针 参数说明:第一个参数为欲打开文件的文件路径及文件名,第二个参数表示对文件的打

fwrite,fread and fprintf,fscanf的一些使用体会

这周一直在完成一个任务,就是将训练出的多个model写成一个model.其中我们使用了c语言的读写方法,搞了一星期, 挖了很多坑,最终都铲平了.下面列举出若干有用的知识. 1.fwrite,fread VS fprintf,fscanf的区别 fwrite,fread 读写的时候,我发现不管使用FILE* pFile = fopen("myfile.bin", "wb");无论是使用"wb"还是"w",最后写出的数据均是乱码,

存储过程和存储函数和触发器示例

1.存储过程示例:为指定的职工在原工资的基础上长10%的工资 SQL> create or replace procedure raiseSalary(empid in number) as pSal emp.sal%type; begin select sal into pSal from emp where empno=empid; update emp set sal = sal*1.1 where empno=empid; dbms_output.put_line('员工号:' || e