• fread()和fwrite()函数分析


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

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

    #i nclude <stdio.h>

    #i nclude <string.h>

    int main()

    {

       FILE *fp;

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

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

        {

           printf("open failed!");

           exit(1);

        }

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

       fclose(fp);

       return 0;

    }

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

    #i nclude <stdio.h>

    #i nclude <mem.h>

    int main()

    {

       FILE *fp;   int len;

       char buffer[100];

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

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

        {

           printf("open failed!");

           exit(1);

        }

       fseek(fp, 0L, SEEK_END);

       len = ftell(fp);

       rewind(fp);

       fread(buffer, 1, len , fp);

       printf("%s",buffer);

       fclose(fp);

       getch();

       return 0;

    }

    可以看到,当我们使用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;这样问题也可得到解决。

  • 相关阅读:
    SQLServer学习笔记系列1
    结束回忆的2014,带着精彩奔向2015!
    sql重置自增长
    回首一年的骚动岁月
    IIS7.5上的REST服务的Put,Delete操作发生HTTP Error 405.0
    Javascript学习笔记1
    C#基础回顾(三)—索引器、委托、反射
    C#基础回顾(二)—页面值传递、重载与重写、类与结构体、装箱与拆箱
    C#基础回顾(一)—C#访问修饰符
    SQL连接
  • 原文地址:https://www.cnblogs.com/watchdatalearn2012620/p/3092289.html
Copyright © 2020-2023  润新知