freadc語言
Ⅰ c語言fread函數
是"\0" 因為字元串本身結尾就是有一個"\0" 不是函數添加的 你用strlen函數列印一下長度就知道了
Ⅱ c語言中fread的用法
fread是以記錄為單位的I/O函數,fread和fwrite函數一般用於二進制文件的輸入輸出。下面我就跟你們詳細介紹下c語言中fread的用法,希望對你們有用。
c語言中fread的用法如下:
#include <stdio.h>
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 <stdio.h>
#include <stdlib.h>
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 <stdio.h>
#include <stdlib.h>
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: %s Age1: %d ", array[0].name, array[0].age);
printf("Name2: %s Age2: %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語言文件操作fwrite和fread
fread是C語言標准為中的一個函數。它從一個文件流中讀數據,最多讀取count個元素,每個元素size位元組,如果調用成功返回實際讀取到的元素個數,如果不成功或讀到文件末尾返回 0。
fwrite是C語言標准庫中的一個函數,指向文件寫入一個數據塊。示例如下:
//讀取一個完整的文件
#include<stdio.h>
#include<stdlib.h>
intmain()
{
FILE*pFile;//文件指針
longlSize;//用於文件長度
char*buffer;//文件緩沖區指針
size_tresult;//返回值是讀取的內容數量
pFile=fopen("myfile.bin","rb");
if(pFile==NULL){fputs("Fileerror",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("Memoryerror",stderr);exit(2);}//內存分配錯誤,退出2
//該文件復制到緩沖區
result=fread(buffer,1,lSize,pFile);//返回值是讀取的內容數量
if(result!=lSize){fputs("Readingerror",stderr);exit(3);}//返回值如果不和文件大小,讀錯誤
//terminate//文件終止
fclose(pFile);
free(buffer);
return0;
}
綜合使用的例子。
#include<stdio.h>
intmain()
{
FILE*pFile;
floatbuffer[]={2.0,3.0,8.0};
pFile=fopen("myfile.bin","wb");//打開文件寫操作
fwrite(buffer,1,sizeof(buffer),pFile);//把浮點數組寫到文件myfile.bin
fclose(pFile);//關閉文件
floatread[3];
pFile=fopen("myfile.bin","rb");//重新打開文件讀操作
fread(read,1,sizeof(read),pFile);//從文件中讀數據
printf("%f %f %f ",read[0],read[1],read[2]);
fclose(pFile);//關閉文件
return0;
}
Ⅳ C語言 fread函數
如果你想把這8個位元組當成一個數來讀的話可以這樣(在VC環境下)
__int64 a;
fread(&a,sizeof(__int64),1,fp);
如果你想分別讀出這8個位元組的話,可以這樣:
char a[8];
fread(a,sizeof(char),8,fp);
希望對你有幫助
__int64也可以用來表示一個整數,只不過它能表示的范圍比int類型的要大,int類型佔4個位元組,而這個__int64佔8個位元組。如果你用的是gcc編譯器(像DEV-C等),那應該是long long
Ⅳ C語言中如何使用fread
FILE * fp = open("D:A.txt", "r"); 先用文件指針獲得文件的地址;
char ch = 0; 定義一個字元變數來獲得從文件中讀取的一個字元;
fread(&ch, sizeof(char), 1, fp); 格式如左;
Ⅵ c語言中fread函數怎麼用
c語言中fread函數語法為size_tfread(void*restrictbuffer,size_tsize,size_tcount,FILE*restrictstream)。buffer是指向要讀取的數組中首個對象的指針,size是每個對象的大小(單位是位元組),count是要讀取的對象個數,stream是輸入流。通過fread函數可進行數據讀取,返回成功讀取的對象個數。
(6)freadc語言擴展閱讀:
fread函數從給定輸入流stream讀取最多count個對象到數組buffer中(相當於以對每個對象調用size次fgetc),把buffer當作unsignedchar數組並順序保存結果。流的文件位置指示器前進讀取的位元組數。
若出現錯誤,則流的文件位置指示器的位置不確定。若沒有完整地讀入最後一個元素,則其值不確定,可能小於count。若size或count為零,則fread返回零且不進行其他動作。fread不區分文件尾和錯誤,因此調用者必須用feof和ferror才能判斷發生了什麼。
Ⅶ 關於C語言fread的用法
簡介
fread
功
能:
從一個流中讀數據
函數原型:
size_t
fread(
void
*buffer,
size_t
size,
size_t
count,
file
*stream
);
參
數:
1.用於接收數據的地址(指針)(buffer)
2.單個元素的大小(size)
:單位是位元組而不是位,例如讀取一個整型數就是2個位元組
3.元素個數(count)
4.提供數據的文件指針(stream)
返回值:成功讀取的元素個數
程序例
#include
int
main(void)
{
file
*stream;
char
msg[]
=
"this
is
a
test";
char
buf[20];
if
((stream
=
fopen("mmy.fil",
"w+"))
==
null)
{
fprintf(stderr,
"cannot
open
output
file.\n");
return
1;
}
/*
write
some
data
to
the
file
*/
fwrite(msg,
strlen(msg)+1,
1,
stream);
/*
seek
to
the
beginning
of
the
file
*/
fseek(stream,
0,
seek_set);
/*
read
the
data
and
display
it
*/
fread(buf,
strlen(msg)+1,
1,stream);
printf("%s\n",
buf);
fclose(stream);
return
0;
}
Ⅷ C語言 fread()函數
fopen的參數指明文件是以只寫方式打開的,所以fread會失敗。fread失敗後a的值是不會改變的。