首页 > 游戏测评 >  > 

fread函数的用法 fread函数的用法和作用

matlab 中关于fread函数的用法

“fread”以二进制形式,从文件读出数据。

fread函数的用法 fread函数的用法和作用fread函数的用法 fread函数的用法和作用


fread函数的用法 fread函数的用法和作用


fread函数的用法 fread函数的用法和作用


fread函数的用法 fread函数的用法和作用


fread函数的用法 fread函数的用法和作用


语法1:[a,count]=fread(fid,size,precision)

语法2:[a,count]=fread(fid,size,precision,skip)

size: 不指定 :到尾返回读。

N : 读出N个数据,构成列向量。

inf : 读出fid指向的打开的文件的全部数据。

[M,N] : 读出N个数据,构成列向量,填入MN矩阵

precision(精度)

precision(精度)规定了以浮点数、整型数、字符读出时位。matlab 的precision(精度)的表达式与c语言、fortran语言、是一致的。不规定precision(精度),则字符默认为: ucher、则数值默认为:双精度 。

以下precision(精度)将保证读出具有一致的体积。

MATLAB C or Fortran Descriphon(精度)

'char' 'charl' 8 位,字符型

'uchar' 'unsigned char' 8 位

'schar' 'signed char' 8 位,字符型

'int8' 'integer1' 8 位,整型数

'intl6' 'integer2' 16 位,整型数.

'int32' 'integer4' 32 位,整型数.

'int64' 'integer8' 64 位,整型数

'uint8' 'integerl' 8 位

'uintl6' 'integer2' 16 位

'uint32' 'integer4' 32 位

'uint64' 'integer8' 64 位

'float32' 'real4' 浮点数, 32 位

'float64' 'real8' 浮点数, 32 位

以下precision(精度)将不保证读出具有一致的体积。

MATLAB C or Fortran Descriphon(精度)

'short' 'short' 16 位,整型数

'int' 'int' 32 位,整型数

'long' 'long' 32 (64) 位,整型数

'uShort' 'Unsigned short' 16 位

'uint' 'Unsigned int' 32 位

'ulong' 'unsigned long' 32 (64) 位

'float' 'float' 浮点数, 32 位

'double' 'double' 浮点数, 64 位

以下precision(精度)规定读出指定的体积n。

'bitN' N位,整型数 1<=N<=64

'ubitN' N位, 1<=N<=64

文件必须在Matlab可以搜索的路径中。

一般为提高速度,直接指定位置,比如指定C盘文件myfile

fid=fread('C:myfile','r')

c语言中fread的用法

fread是以记录为单位的I/O函数,fread和fwrite函数一般用于二进制文件的输入输出。下面我就跟你们详细介绍下c语言中fread的用法,希望对你们有用。

c语言中fread的用法如下:

#include

size_t fwrite(const void ptr, size_t size, size_t nmemb, FILE stream);

返回值:读或写的记录数,成功时返回的记录数等于nmemb,出错或读到文件末尾时返回的记录

数小于nmemb,也可能返回0。

fread用于读写记录,这里的记录是指一串固定长度的字节,比如一个int、一个结构体或者一个定长数组。参数size指出一条记录的长度,而nmemb指出要读或写多少条记录,这些记录在ptr所指的内存空间中连续存放,共占size nmemb个字节,fread从文件stream中读出size nmemb个字节保存到ptr中,而fwrite把ptr中的size nmemb个字节写到文件stream中。

nmemb是请求读或写的记录数,fread和返回的记录数有可能小于nmemb指定的记录数。例如当前读写位置距文件末尾只有一条记录的长度,调用fread时指定nmemb为2,则返回值为1。如果当前读写位置已经在文件末尾了,或者读文件时出错了,则fread返回0。如果写文件时出错了,则fwrite的返回值小于nmemb指定的值。下面的例子由两个程序组成,一个程序把结构体保存到文件中,另一个程序和从文件中读出结构体

fread的例子程序如下:

/ -------------------writerec.c--------------- /

#include

#include

struct record {

char name[10];

int age;

};

int main(void)

{struct record array[2] = {{"Ken", 24}, {"Knuth", 28}};

FILE fp = fopen("recfile", "w");

if (fp == NULL) {

perror("Open file recfile");

exit(1);

}fwrite(array, sizeof(struct record), 2, fp);

fclose(fp);

return 0;

}/ -------------------readrec.c----------------- /

#include

#include

struct record {

char name[10];

int age;

};

int main(void)

{struct record array[2];

FILE fp = fopen("recfile", "r");

if (fp == NULL) {

perror("Open file recfile");

exit(1);

}fread(array, sizeof(struct record), 2, fp);

printf("Name1: %stAge1: %d

", array[0].name, array[0].age);

printf("Name2: %stAge2: %d

", array[1].name, array[1].age);

fclose(fp);

return 0;

}$ gcc writerec.c -o writerec

$ gcc readrec.c -o readrec

发现生成的文件recfile不能直接打开。

原因:我们把一个struct record结构体看作一条记录,由于结构体中有填充字节,每条记录占16字节,

把两条记录写到文件占32字节。该程序生成的recfile文件是二进制文件而非文本文件,因为其

中不仅保存着字符型数据,还保存着整型数据24和28(在od命令的输出中以八进制显示为030和034)。

注意,直接在文件中读写结构体的程序是不可移植的,如果在一种平台上编译运行writebin.c程序,

把生成的recfile文件拷到另一种平台并在该平台上编译运行readbin.c程序,则不能保证正确读出

文件的内容,因为不同平台的大小端可能不同(因而对整型数据的存储方式不同),结构体的填充方式

也可能不同(因而同一个结构体所占的字节数可能不同,age成员在name成员之后的什么位置也可能不同)。

通过readrec程序读取文件recfile的内容,说明writerec程序的确记录成功写入recfile中。

从recfile读出的内容如下:

Name1: Ken Age1: 24

Name2: Knuth Age2: 28

fwrite和fread的应用举例:

1.将一个字符串写入文件:

char str="hello,I am a test program!";

fwrite(str,sizeof(char),strlen(str),fp)

2.将一个字符数组写入文件:

char str[]={'a','b','c','d','e'};

fwrite(str,sizeof(char),sizeof(str),fp)

3.将一个整型数组写入文件:

int a[]={12,33,23,24,12};

先计算数组元素个数nmemb,之后

fwrite(a,sizeof(int),nmemb,fp)

注:由于程序生成的文件是二进制文件而非文本文件,因此,不用机器,整数的表达不同,

所以无法直接打开生成文件。可通过fread函数检验数据是否写入文件。

请教C语言头文件下的fread()函数的用法,结合一个简单的例子加上一些解释。

函数原型

size_t fread ( void buffer, size_t size, size_t count, FILE stream) ;

参 数

buffer

用于接收数据的内存地址

size

要读写的字节数,单位是字节

count

要进行读写多少个size字节的数据项,每个元素是count字节.

stream

输入流

#include

#include

int main(void)

{FILEstream;

char msg[]="thisisatest";

char buf[20];

if((stream=fopen("DUMMY.FIL","w+"))==NULL)

{fprintf(stderr,"Cannotopenoutputfile.n");

return 0;

}/writesomedatatothefile/

fwrite(msg,1,strlen(msg)+1,stream);

/sizeof(char)=1seektothebeginningofthefile/

fseek(stream,0,SEEK_SET);

/readthedataanddisplayit/

fread(buf,strlen(msg)+1,1,stream);

printf("%sn",buf);

fclose(stream);

return0;

}

c语言fread函数的用法

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.如果调用成功则实际读取sizecount字节

buffer的大小至少是 sizecount 字节.

return:

fread returns the number of full s actually read

实际读取的元素数.如果返回值与count(不是countsize)不相同,则可能文件结尾或发生错误.

从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("%sn",buf);

fclose(stream);

("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 sn",numwritten);

fclose(stream);

}else

printf("Problem opening the filen");

if ((stream=fopen("fread.out","r+t"))!=NULL)

{numread=fread(list,sizeof(char),25,stream);

printf("Number of s read =%dn",numread);

printf("Contents of buffer=%.25sn",list);

fclose(stream);

}else

{printf("File could not be openedn");

}("pause");

return 0;

}

fread函数的用法

fread函数可从文件中读取二进制数据。

语法:

A=fread(fid,count)

A=fread(fid,count,precision)

其中fid为指针所指文件中的当前位置,count指读取的数据个数,precision表示以什么格式的数据类型读取数据。

fread:从给定输入流stream读取最多count个对象到数组buffer中(相当于以对每个对象调用count次fgetc),把buffer当作unsignedchar数组并顺序保存结果。流的文件位置指示器前进读取的字节数。

版权声明:本文内容由互联网用户自发贡献。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 836084111@qq.com,本站将立刻删除。