操作系统大型实验进展(7)-----C语言函数fopen

来源:互联网 发布:层次分析法软件 编辑:程序博客网 时间:2024/05/17 06:00
C语言函数fopen

函数简介

  函数功能:打开一个文件
  函数原型:FILE * fopen(const char * path,const char * mode);
  相关函数:open,fclose,fopen_s,_wfopen
  所需库:<stdio.h>
  返回值:文件顺利打开后,指向该流的文件指针就会被返回。如果文件打开失败则返回NULL,并把错误代码存在errno 中。
  一般而言,打开文件后会作一些文件读取或写入的动作,若打开文件失败,接下来的读写动作也无法顺利进行,所以一般在fopen()后作错误判断及处理。
  参数说明:
  参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。
  mode有下列几种形态字符串:
  r 以只读方式打开文件,该文件必须存在。
  r+ 以可读写方式打开文件,该文件必须存在。
  rb+ 读写打开一个二进制文件,允许读数据。
  rw+ 读写打开一个文本文件,允许读和写。
  w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
  w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
  a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
  a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)
  wb 只写打开或新建一个二进制文件;只允许写数据。
  wb+ 读写打开或建立一个二进制文件,允许读和写。
  ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
  at+ 打开一个叫string的文件,a表示append,就是说写入处理的时候是接着原来文件已有内容写入,不是从头写入覆盖掉,t表示打开文件的类型是文本文件,+号表示对文件既可以读也可以写。
  上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b 字符用来告诉函数库以二进制模式打开文件。如果不加b,表示默认加了t,即rt,wt,其中t表示以文本模式打开文件。由fopen()所建立的新文件会具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)权限,此文件权限也会参考umask 值。
  有些C编译系统可能不完全提供所有这些功能,有的C版本不用"r+","w+","a+",而用"rw","wr","ar"等,读者注意所用系统的规定。
  二进制和文本模式的区别
  1.在windows系统中,文本模式下,文件以"\r\n"代表换行。若以文本模式打开文件,并用fputs等函数写入换行符"\n"时,函数会自动在"\n"前面加上"\r"。即实际写入文件的是"\r\n" 。
  2.在类Unix/Linux系统中文本模式下,文件以"\n"代表换行。所以Linux系统中在文本模式和二进制模式下并无区别。

程序示例

  程序示例1
  #include <stdio.h>
  #include <stdlib.h> //为了使用exit()
  int main()
  {
  char ch;
  FILE* fp;
  char fname[50]; //用于存放文件名
  printf("输入文件名:");
  scanf("%s",fname);
  fp=fopen(fname,"r"); //只供读取
  if(fp==NULL) //如果失败了
  {
  printf("错误!");
  exit(1); //中止程序
  }
  //getc()用于在打开文件中获取一个字符
  while((ch=getc(fp))!=EOF)
  putchar(ch);
  fclose(fp); //关闭文件
  return 0;
  }
  注意!初学者往往会犯一个错误,即在输入文件名时不加后缀名,请注意加上!
  程序示例2
  #include <stdio.h>
  FILE *stream, *stream2;
  int main( void )
  {
  int numclosed;
  // Open for read (will fail if file "crt_fopen.c" does not exist)
  if( (stream = fopen( "crt_fopen.c", "r" )) == NULL ) // C4996
  // Note: fopen is deprecated; consider usingfopen_s instead
  printf( "The file 'crt_fopen.c' was notopened\n" );
  else
  printf( "The file 'crt_fopen.c' wasopened\n" );
  // Open for write
  if( (stream2 = fopen( "data2", "w+" )) == NULL ) // C4996
  printf( "The file 'data2' was not opened\n" );
  else
  printf( "The file 'data2' was opened\n" );
  // Close stream if it is not NULL
  if( stream)
  {
  if ( fclose( stream ) )
  {
  printf( "The file 'crt_fopen.c' was not closed\n" );
  }
  }
  // All other files are closed:
  numclosed = _fcloseall( );
  printf( "Number of files closed by _fcloseall: %u\n", numclosed );
  }

在文件操作时,需要注意以下几点问题

  1、在定义文件指针时,要将文件指针指向空;如 FILE *fp = NULL;
  2、文件操作完成后,需要将文件关闭,一定要注意,否则会造成文件所占用内存泄露和在下次访问文件时出现问题。
  3、文件关闭后,需要将文件指针指向空,这样做会防止出现游离指针,而对整个工程造成不必要的麻烦;如:fp = NULL;
  示例程序:
  #include <stdio.h>
  #define F_PATH "d:\myfile\file.dat"
  int main(void)
  {
  FILE *fp = NULL; //需要注意
  fp = fopen(F_PATH, "r");
  if(NULL == fp)
  {
  return -1; //要返回错误代码
  }
  fclose(fp);
  fp = NULL; //需要指向空,否则会指向原打开文件地址
  return 0;
  }