fwrite函数与fread 我每次用fwrite写数据 再fread读数据 但输出数据后面都会跟乱码,是怎么回事

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了fwrite函数与fread 我每次用fwrite写数据 再fread读数据 但输出数据后面都会跟乱码,是怎么回事相关的知识,希望对你有一定的参考价值。

写数据:
while(p1!=NULL)

fwrite(p1,sizeof(struct Book),1,fp);
p1=p1->next;

读数据:
while(1)

if(feof(fp))

break;

p0=(struct Book*)malloc(sizeof(struct Book));
fread(p0,sizeof(struct Book),1,fp);

Insert(p0); //将结构体插入到链表中,无问题

大哥,你的buffer没有预先清空重置就会这样的,
你试试这样定义
char in_read[256]="\0", out_write[256]="\0";
或者每次读数据的之前手动把你的buffer清空为全0x0然后再fread读入数据,这样:
memset(in_read,256,0x0);
同样,每次需要设置写入的数据之前先把写入的buffer清空一下。然后再拷贝写入的数据

memset(out_write,256,0x0);
memcpy(out_write, my_write_data, 256);

我保证你再输出不会有乱码了,望采纳。
参考技术A fwrite后,需将文件关掉重开,或者用fseek 重新定位到文件头,不然,默认是重fwrite后面读取数据本回答被提问者采纳 参考技术B 文件第一次打开时候,读写指针会在起始位置,你这里写入后读写指针已经变了,可是你在读的时候并没有把文件读写指针移到起始位置。追问

读的时候怎么移到起始位置呢?

追答

有相应的函数的,你去查一下。

追问

对了。,我在写好后 把fp指针fclose 了,在读的时候又打开的,所以就是在开头吧

追答

应该是这样,如果打开后,写入,后直接读出需要重新设置读写指针,如果关闭后再打开就不用

参考技术C 这个我也碰到过,可能是因为你打开的时候没有用二进制打开,
fp=fopen("filename", "rb");
还有可能是因为写的字节数的原因追问

读写字节数都是book类大小啊

追答

关键是里面的内容,有可能结构的大小与实际所存储的大小不同。
还有,有可能文件的编码的不同,比如说utf-8,unicode等

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

fopen()函数:

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

2.函数原型:

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

fwrite()函数:

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

2.函数原型:

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

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

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

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

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

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

  1. 注意事项:

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

示例说明:

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

#include "stdafx.h"
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#define DATA_SIZE 1024
 
int main()
{
    unsigned int *dataPtr = NULL;
    dataPtr = (unsigned int *)malloc(sizeof(int)*DATA_SIZE);
    for(unsigned int i=0;i<DATA_SIZE;i++)
    {
        dataPtr[i] = i; //初始化缓存区
    }
    FILE *fp = fopen("F:\Labwindows cvi\test.txt","w");
    fwrite(dataPtr,sizeof(int),DATA_SIZE,fp);
       fclose(fp);
       free(dataPtr);
    system("pause");
    return 0;
}

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

// datasave.cpp : 定义控制台应用程序的入口点。
//
 
#include "stdafx.h"
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#define DATA_SIZE 1024
 
int main()
{
    unsigned int *dataPtr = NULL;
    dataPtr = (unsigned int *)malloc(sizeof(int)*DATA_SIZE);
    for(unsigned int i=0;i<DATA_SIZE;i++)
    {
        dataPtr[i] = i; //初始化缓存区
    }
    FILE *fp = fopen("F:\Labwindows cvi\test.txt","ab+");
    fwrite(dataPtr,1,DATA_SIZE*sizeof(unsigned int),fp);
fclose(fp);
free(dataPtr);

system("pause");    
return 0;
    
}
代码3:

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

// datasave.cpp : 定义控制台应用程序的入口点。
//
 
#include "stdafx.h"
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#define DATA_SIZE 1024
 
int main()
{
    unsigned char *dataPtr = NULL;
    dataPtr = (unsigned char *)malloc(sizeof(int)*DATA_SIZE); //申请的区域是4096个char,即1024个字的区域
    for(unsigned int i=0;i<DATA_SIZE;i++)
    {
        dataPtr[i] = i; //初始化缓存区
    }
    FILE *fp = fopen("F:\Labwindows cvi\test.txt","ab+");
    fwrite(dataPtr,sizeof(char),DATA_SIZE*sizeof(int),fp);
    fclose(fp);      
       free(dataPtr);
    system("pause");
    return 0;
}
代码4:

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

// datasave.cpp : 定义控制台应用程序的入口点。
//
 
#include "stdafx.h"
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#define DATA_SIZE 1024
 
int main()
{
    unsigned char *dataPtr = NULL;
    unsigned int *Ptr = NULL;
    dataPtr = (unsigned char *)malloc(sizeof(int)*DATA_SIZE);
    Ptr = (unsigned int *) dataPtr;
    for(unsigned int i=0;i<DATA_SIZE;i++)
    {
        Ptr[i] = i; 
    }
    FILE *fp = fopen("F:\Labwindows cvi\test.txt","ab+");
    fwrite(Ptr,sizeof(unsigned int),DATA_SIZE,fp);
    fclose(fp);
    free(dataPtr);
   system("pause");
    return 0;
}
fread()函数:
  1. 作用:从一个文件流中读取数据
  2. 函数原型如下:
    size_t fread(void *buffer, size_t size, size_t count, FILE *stream);
      -- buffer:指向数据块的指针
      -- size:每个数据的大小,单位为Byte(例如:sizeof(int)就是4)
      -- count:数据个数
      -- stream:文件指针

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

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

代码参考:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
 
int main(int argc, char *argv[])
{
    FILE *filp = NULL;
    char fileDir[] = "/home/yangzhiyuan/Documents/test.txt"; 
    char dataPtr[] = "Helloworld";
    printf("sizeof(dataPtr) = %ld
",sizeof(dataPtr));
    filp = fopen(fileDir,"w+");  /* 可读可写,不存在则创建 */
    int writeCnt = fwrite(dataPtr,sizeof(dataPtr),1,filp);  /* 返回值为1 */
    //int writeCnt = fwrite(dataPtr,1,sizeof(dataPtr),filp);  /* 返回值为11 */
    printf("writeCnt = %d
",writeCnt);
    fclose(filp);
 
    FILE *fp = NULL;
    fp = fopen(fileDir,"r");
    char buffer[256];
    int readCnt = fread(buffer,sizeof(buffer),1,fp);  /* 返回值为0 */
    //int readCnt = fread(buffer,1,sizeof(buffer),fp);  /* 返回值为11 */    
    printf("readCnt = %d
",readCnt);
    fclose(fp);
    
    printf("%s
",buffer);
    exit(0);
}
注意:

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






以上是关于fwrite函数与fread 我每次用fwrite写数据 再fread读数据 但输出数据后面都会跟乱码,是怎么回事的主要内容,如果未能解决你的问题,请参考以下文章

fread与fwrite的自我理解

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

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

fread和fwrite的使用

fread函数和fwrite函数

如何使用 fread 和 fwrite 函数读写二进制文件?