fread和fwrite,c语言 ,fread,fwrite和fscanf,fprint不知格式化方式和二进制方式的区别
fread和fwrite,c语言 ,fread,fwrite和fscanf,fprint不知格式化方式和二进制方式的区别详细介绍
本文目录一览: fread和fwrite的区别是什么
fread(pBuffer,size,count,pFile);
fwrite(pBuffer,size,count,pFile);
要读写一个数据块的话,无论是读还是写,都需要指定一个起始地址,读的话从这个起始地址读,写的话从这个起始地址写,上面函数定义中的第一个参数pBuffer就是用于指定这个起始地址,size读写的字节数,count则指定读写多少个size大小的数据,pFile是文件结构指针。
更多详细介绍以及使用示例请看参考资料
fwrite:向流中写数据
fread:从流中读数据
fwrite和fread是以记录为单位的I/O函数,fread和fwrite函数一般用于二进制文件的输入输出。
fread和fwrite的函数原型分别为:
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);
fread和fwrite函数的返回值:
读或写的记录数,成功时返回的记录数等于nmemb,出错或读到文件末尾时返回的记录数小于nmemb,也可能返回0。
fread和fwrite函数参数的含义:
参数size指出一条记录的长度;
参数nmemb指出要读或写多少条记录,这些记录在ptr所指的内存空间中连续存放,共占size * nmemb个字节;
ptr是指向的某连续内存空间的指针;
stream是文件指针;
fread从文件stream中读出size * nmemb个字节保存到ptr中所指的内存空间中;
fwrite把ptr中的size * nmemb个字节写到文件stream中。
fwrite()函数和fread()函数分别有几个返回值?分别代表什么意思?(C语言)
分类: 电脑/网络 >> 程序设计 >> 其他编程语言
解析:
fwrite(将数据写至文件流)
相关函数 fopen,fread,fseek,fscanf
表头文件 #include
定义函数 size_t fwrite(const void * ptr,size_t size,size_t nmemb,FILE * stream);
函数说明 fwrite()用来将数据写入文件流中。参数stream为已打开的文件指针,参数ptr 指向欲写入的数据地址,总共写入的字符数以参数size*nmemb来决定。Fwrite()会返回实际写入的nmemb数目。
返回值 返回实际写入的nmemb数目。
范例 #include
#define set_s (x,y) {strcoy(s[x].name,y);s[x].size=strlen(y);}
#define nmemb 3
struct test
{
char name[20];
int size;
}s[nmemb];
main()
{
FILE * stream;
set_s(0,”Linux!”);
set_s(1,”FreeBSD!”);
set_s(2,”Windows2000.”);
stream=fopen(“/tmp/fwrite”,”w”);
fwrite(s,sizeof(struct test),nmemb,stream);
fclose(stream);
}
执行 参考fread()。
fread(从文件流读取数据)
相关函数 fopen,fwrite,fseek,fscanf
表头文件 #include
定义函数 size_t fread(void * ptr,size_t size,size_t nmemb,FILE * stream);
函数说明 fread()用来从文件流中读取数据。参数stream为已打开的文件指针,参数ptr 指向欲存放读取进来的数据空间,读取的字符数以参数size*nmemb来决定。Fread()会返回实际读取到的nmemb数目,如果此值比参数nmemb 来得小,则代表可能读到了文件尾或有错误发生,这时必须用feof()或ferror()来决定发生什么情况。
返回值 返回实际读取到的nmemb数目。
附加说明
范例 #include
#define nmemb 3
struct test
{
char name[20];
int size;
}s[nmemb];
main()
{
FILE * stream;
int i;
stream = fopen(“/tmp/fwrite”,”r”);
fread(s,sizeof(struct test),nmemb,stream);
fclose(stream);
for(i=0;i
<nmemb;i++)
printf(“name[%d]=%-20s:size[%d]=%d\n”,i,s[i].name,i,s[i].size);
}
执行 name[0]=Linux! size[0]=6
name[1]=FreeBSD! size[1]=8
name[2]=Windows2000 size[2]=11
</nmemb;i++)
C语言中fread,fwrite和fscanf,fprintf的区别,什么是格式化数据
fread:是读取数据
fwrite:是写入数据
1.函数功能
用来读写一个数据块。
2.一般调用形式
fread(buffer,size,count,fp);
fwrite(buffer,size,count,fp);
3.说明
(1)buffer:是一个指针,对fread来说,它是读入数据的存放地址。对fwrite来说,是要输出数据的地址。
(2)size:要读写的字节数;
(3)count:要进行读写多少个size字节的数据项;
(4)fp:文件型指针。
注意:1 完成次写操(fwrite())作后必须关闭流(fclose());
2 完成一次读操作(fread())后,如果没有关闭流(fclose()),则指针(FILE * fp)自动向后移动前一次读写的长度,不关闭流继续下一次读操作则接着上次的输出继续输出;
3 fprintf() : 按格式输入到流,其原型是int fprintf(FILE *stream, const char *format[, argument, ...]);其用法和printf()相同,不过不是写到控制台,而是写到流罢了。注意的是返回值为此次操作写入到文件的字节数。如int c = fprintf(fp, "%s %s %d %f", str1,str2, a, b) ;str1:10字节;str2: 10字节;a:2字节;b:8字节,c为33,因为写入时不同的数据间自动加入一个空格。
4.fscanf 和 scanf 相似 :当能正常读入数据时, fscanf 返回读入数据的个数,否则返回 EOF 。
关于CC++里FILE的fwrite和fread怎么用。
fseek找到读写的位置
fread从流中读指定_个数的字符,原型是size_t
fread(void
ptr,
size_t
size,
size_t
n,
FILE
*stream);参数ptr是保存读取的数据,void的指针可用任何类型的指针来替换,如char*、int
等等来替换;size是每块的字节数;n是读取的块数,如果成功,返回实际读取的块数(不是字节数),本函数一般用于二进制模式打开的文件中_
fwrite
与fread对应,向流中写指定的数据,原型是size_t
fwrite(const
void
*ptr,
size_t
size,
size_t
n,
FILE
*stream);参数ptr是要写入的数据指针,void的指针可用任何类型的指针来替换,如char*、int
*等等来替换;size是每块的字节数;n是要写的块数,如果成功,返回实际写入的块数(不是字节数),本函数一般用于二进制模式打开的文件中**
C语言如何用fread()和fwrite()实现对文本文件的整行读写呢,文本文件中每一行的字符个数不一定相同
最好用fgets()来读取一行,该函数自动读取一行。
写的时候你就可以自己随意定啦!你在buf后面加个换行符'\n'就行了,fwrite()就会自动换行了。
比如:
FILE* fp = fopen("c:\\test.txt","rw"); //打开文件
if( fp == NULL )
return;
char achBuf[256] = {0};
fgets( achBuf,fp ); //读取一行,直到遇到换行符结束
memset( achBuf,0,256 );
strcpy(achBuf,"Hello,world!\n"); //内容随意,别忘了加个换行符
fwrite( achBuf,1,strlen(achBuf)+1,fp ); //写入一行
fclose(fp); //关闭文件
fread()和fwrite()主要是用来读写二进制文件的。
如果是文本文件建议使用fprintf()和fscanf()
如果一次读取一行,用fgets()最方便了。
c语言文件操作fwrite和fread
无语的写法..
你根本分不清什么事数字 什么事字符
如果你要输出txt里面的内容比较简单.
char buf[1024];
fread(&stud[j],sizeof(struct student),1,fp1);
改成
fread(buf,1024,1,fp1);
printf 改成 printf(%s, buf);
如果你要把 txt里面的字符变成数据.
那就需要解析txt了
读了你的代码,我觉得,你在用fread的时候,其实你的意图是想将1.txt中的每一行按照你所定义的structure student中的字段格式,进行读取,将你的stud一个一个填充好。很遗憾,fread并不能做这件事情。fread会将1.txt中的每行看做一整个字符串,写到你给的每个&stud[j]开头的地址空间中,而无视你所给定的structure的定义,自然你printf就得不到预想的结果了。而fwrite倒是可以原原本本将写入的字串回写出来。
如果你想要按structure的格式读入1.txt的数据,那么就要用scanf咯。就像printf那样,scanf的用法你一定是懂的。
fread是C语言标准为中的一个函数。它从一个文件流中读数据,最多读取count个元素,每个元素size字节,如果调用成功返回实际读取到的元素个数,如果不成功或读到文件末尾返回 0。
fwrite是C语言标准库中的一个函数,指向文件写入一个数据块。示例如下:
//读取一个完整的文件#include
#include
int main(){ FILE* pFile; //文件指针 long lSize; // 用于文件长度 char* buffer; // 文件缓冲区指针 size_t result; // 返回值是读取的内容数量 pFile = fopen("myfile.bin" , "rb"); if (pFile == NULL) {fputs("File error", stderr); exit(1);} // 如果文件错误,退出1 // 获得文件大小 fseek(pFile , 0 , SEEK_END); // 指针移到文件末位 lSize = ftell(pFile); // 获得文件长度 rewind(pFile); // 函数rewind()把文件指针移到由stream(流)指定的开始处, 同时清除和流相关的错误和EOF标记 // 为整个文件分配内存缓冲区 buffer = (char*) malloc(sizeof(char) * lSize); // 分配缓冲区,按前面的 lSize if (buffer == NULL) {fputs("Memory error", stderr); exit(2);} // 内存分配错误,退出2 // 该文件复制到缓冲区 result = fread(buffer, 1, lSize, pFile); // 返回值是读取的内容数量 if (result != lSize) {fputs("Reading error", stderr); exit(3);} // 返回值如果不和文件大小,读错误 // terminate // 文件终止 fclose(pFile); free(buffer); return 0;}综合使用的例子。
#include
int main(){ FILE* pFile; float buffer[] = { 2.0 , 3.0 , 8.0 }; pFile = fopen("myfile.bin" , "wb"); // 打开文件写操作 fwrite(buffer , 1 , sizeof(buffer) , pFile); // 把浮点数组写到文件 myfile.bin fclose(pFile); // 关闭文件 float read[3]; pFile = fopen("myfile.bin" , "rb"); // 重新打开文件读操作 fread(read , 1 , sizeof(read) , pFile); // 从文件中读数据 printf("%f\t%f\t%f\n", read[0], read[1], read[2]); fclose(pFile); // 关闭文件 return 0;}
linux readwrite和freadfwrite有什么区别
1、fread是带缓冲的,read不带缓冲.
2、fopen是标准c里定义的,open是POSIX中定义的.
3、fread可以读一个结构.read在linux/unix中读二进制与普通文件没有区别.
4,fopen不能指定要创建文件的权限.open可以指定权限.
5、fopen返回指针,open返回文件描述符(整数).
6、linux/unix中任何设备都是文件,都可以用open,read.
7、fread与read的区别
f是ANSI的C标准库。而后者的是UNIX下的系统调用。
fread带有缓冲,是read的衍生,或者说fread是通过read实现的
要想直接和硬件打交道,必须用read
例子:
如果文件的大小是8k。
你如果用read/write,且只分配了2k的缓存,则要将此文件读出需要做4次系统调用
来实际从磁盘上读出。
如果你用fread/fwrite,则系统自动分配缓存,则读出此文件只要一次系统调用从磁
盘上读出。
也就是用read/write要读4次磁盘,而用fread/fwrite则只要读1次磁盘。效率比read
/write要高4倍。
如果程序对内存有限制,则用read/write比较好。
一般用来处理文件:
都用fread 和fwrite,它自动分配缓存,速度会很快,比自己来做要简单
如果要处理一些特殊的描述符,用read 和write,如套接口,管道之类的
c语言fwrite和fread
以"wb+"方式打开的二进制文件用于读/写,如果这个文件不存在,则建立这个文件,如果存在,则打开这个文件。
读写文件时,还有一个用于读/写文件内容的指针,这个指针随着fread()和fwrite()函数的操作而改变,控制该指针的函数是int fseek(FILE *stream, long offset, int fromwhere);。
就以上原因,修改如下:
#include
int main() { FILE *fp = fopen("a.txt","wb+"); int a,b; a = 5; fwrite(&a,sizeof(int),1,fp); fseek(fp,-(long)sizeof(int),SEEK_CUR); // 从当前位置向后移动读/写指针 fseek(fp,0,SEEK_CUR); // 改变为"读"模式 fread(&b,sizeof(int),1,fp); printf("%d\n",b); fclose(fp); return 0;}
读数据块函数调用的一般形式为:
fread(buffer,size,count,fp);
写数据块函数调用的一般形式为:
fwrite(buffer,size,count,fp);
其中:
buffer 是一个指针,在fread 函数中,它表示存放输入数据的首地址。在fwrite 函
数中,它表示存放输出数据的首地址。
size 表示数据块的字节数。
count 表示要读写的数据块块数。
fp 表示文件指针。
c语言 ,fread,fwrite和fscanf,fprint不知格式化方式和二进制方式的区别
fread 和fscanf都是读函数
fwrite和fprintf都是写函数。
原理类似 以fread和fscanf对比举例
fread是不管文件中什么内容,直接读到内存中, 不考虑格式。
而fscanf在读的时候, 第一步要做的 和fread相同,先读取字符到内存中,然后要解析格式字符串,根据格式字符串,去判断读到的字符,和格式字符串是否相符,如果相符,再转换成对应的变量类型,存到参数指针中。
比如分析格式字符串为%d,那么就要判断读到的字符是不是0~9之间的,是的话 再读下一个,直到读到不是0~9之间的字符。 最后 再把读到的字符,转为整型。
由于有这些判断,转换,所以效率自然低。
至于文件打开的方式是文本或者二进制, 和使用哪个函数没太多关系
一般fscanf用于文本,而fread用于二进制。 但并非绝对,二进制也可以用fscanf,而文本也一样可以用fread的。
read和write,fread和fwrite的区别
fread fwrite是C的标准库函数
read 和write是linux/unix提供的操作接口
简单来说 应用范围不同
前者可以用在任意的C代码中 移植不会有问题
后者只适用于linux/unix平台及兼容了这两个函数的其他平台
对于可以使用read/write的平台来说 对普通文件操作二者没有本质区别
但read/write的应用更广 可以用在一些非标准文件上 比如管道 设备节点等等
PS:还有一个不太重要的区别 fread/fwrite操作的是一个指针FILE *
而read/write操作的标识符是一个int类型的fd