大家好,又见面了,我是你们的朋友全栈君。
C语言中:fread是一个函数。从一个文件流中读数据,最多读取count个元素,每个元素size字节,如果调用成功返回实际读取到的元素个数,如果不成功或读到文件末尾返回 0。下面我们来看看c语言fread函数的用法。
fread()函数—- Reads data from a stream.
#include
size_t fread( void *buffer, size_t size, size_t count,FILE *stream );
从一个文件流中读数据,读取count个元素,每个元素size字节.如果调用成功返回count.如果调用成功则实际读取size*count字节
buffer的大小至少是 size*count 字节.
return:
fread returns the number of full items actually read
实际读取的元素数.如果返回值与count(不是count*size)不相同,则可能文件结尾或发生错误.
从ferror和feof获取错误信息或检测是否到达文件结尾.
DEMO:
[cpp] view plain#include
#include
#include
int main()
{
FILE *stream;
char msg[]=”this is a test”;
char buf[20];
if ((stream=fopen(“dummy.fil”,”w+”))==NULL)
{
fprintf(stderr,”cannot open output file.\n”);
return 1;
}
/*write some data to the file*/
fwrite(msg,1,strlen(msg)+1,stream);
/*seek to the beginning of the file*/
fseek(stream,0,SEEK_SET);
/*read the data and display it*/
fread(buf,1,strlen(msg)+1,stream);
printf(“%s\n”,buf);
fclose(stream);
system(“pause”);
return 0;
}
DEMO2
[cpp] view plainint main(void)
{
FILE *stream;
char list[30];
int i,numread,numwritten;
/*open file in text mode:*/
if ((stream=fopen(“fread.out”,”w+t”))!=NULL)
{
for (i=0;i<25;i++)
{
list[i]=(char)(‘z’-i);
}
/*write 25 characters to stram*/
numwritten=fwrite(list,sizeof(char),25,stream);
printf(“Wrote %d items\n”,numwritten);
fclose(stream);
}
else
printf(“Problem opening the file\n”);
if ((stream=fopen(“fread.out”,”r+t”))!=NULL)
{
numread=fread(list,sizeof(char),25,stream);
printf(“Number of items read =%d\n”,numread);
printf(“Contents of buffer=%.25s\n”,list);
fclose(stream);
}
else
{
printf(“File could not be opened\n”);
}
system(“pause”);
return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/194331.html原文链接:https://javaforall.cn
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有