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); //将结构体插入到链表中,无问题
你试试这样定义
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)
- 注意事项:
写完数据后要调用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()函数:
- 作用:从一个文件流中读取数据
- 函数原型如下:
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读数据 但输出数据后面都会跟乱码,是怎么回事的主要内容,如果未能解决你的问题,请参考以下文章
fopen()fwrite()fread()函数使用说明与示例