现在的位置: 首页 > 综合 > 正文

文件操作之【copy file1 to file2】

2013年04月14日 ⁄ 综合 ⁄ 共 1707字 ⁄ 字号 评论关闭

#include <stdio.h>

void main(int argc,char *argv[])

{

         char ch;

    if(argc!=3)

        printf("\n\nFFORMAT:MYCOPY<source><destin>");

    else

    {

        FILE *source,*destin;

        source=fopen(argv[1],"r");

        destin=fopen(argv[2],"w");

        if(source==NULL)

            printf("can not open the source file %s\n",argv[1]);

        else if(destin==NULL)

            printf("can not open the destin file %s\n",argv[2]);

        else

        {

            while((ch=fgetc(source))!=EOF)

                fputc(ch,destin);

        }

        fclose(source);

        fclose(destin);

    }  

}

 

1,命令行参数的使用:main(int argc,char *argv[])


2,文件结束的判断

开始写的while(!feof(source))    fputc(fgetc(source),destin);老是在最后多出一个乱码;

问题在于:

feof(fp)有两个返回值:如果遇到文件结束,函数feof(fp)的值为1,否则为0

EOF是文件结束标志的文件。在文本文件中,数据是以字符的ASCⅡ代码值的形式存放,ASCⅡ代码的范围是0到255,不可能出现-1,因此可以用EOF作为文件结束标志。

当把数据以二进制形式存放到文件中时,就会有-1值的出现,因此不能采用EOF作为二进制文件的结束标志。为解决这一个问题,ASCI C提供一个feof函数,用来判断文件是否结束。feof函数既可用以判断二进制文件又可用以判断文本文件

“C”语言的“feof()”函数和数据库中“eof()”函数的运做是完全不同的。数据库中“eof()”函数读取当前指针的位置,“C”语言的“feof()”函数返回的是最后一次“读操作的内容”。多年来把“位置和内容”相混,从而造成了对这一概念的似是而非。

那么,位置和内容到底有何不同呢?举个简单的例子,比如有人说“你走到火车的最后一节车箱”这就是位置。而如果说“请你一直向后走,摸到铁轨结束”这就是内容。也就是说用内容来判断会“多走一节”。这就是完全依赖于 “while(!feof(FP)){...}”进行文件复制时,目标文档总会比源文档“多出一些”的原因。

在“C”文件读取操作时不能完全依赖于“while(!feof(FP)){...}”的判断

  与EOF的区别

  在stdio.h中可以看到如下定义:

  #define EOF (-1)

  #define _IOEOF 0x0010

  #define feof(_stream)   ((_stream)->_flag & _IOEOF)

  int c;

  while(!feof(fp))

  {

  c = fgetc(fp);

  printf("%X\n", c);

  }

  会发现多输出了一个FF,原因就是在读完最后一个字符后,fp->flag仍然没有被置为_IOEOF,因而feof()仍然没有探测到文件结尾。直到再次调用fgetc()执行读操作,feof()才能探测到文件结尾。这样就多输出了一个-1(即FF)。

  正确的写法应该是:

  int c;

  c = fgetc(fp);

  while(!feof(fp))

  {

  printf("%X\n", c);

  c = fgetc(fp);

  }

  feof()可以用EOF代替吗?不可以。fgetc返回-1时,有两种情况:读到文件结尾或是读取错误。因此我们无法确信文件已经结束, 因为可能是读取错误! 这时我们需要feof()。


抱歉!评论已关闭.