fwrite,fread and fprintf,fscanf的一些使用体会
這周一直在完成一個(gè)任務(wù),就是將訓(xùn)練出的多個(gè)model寫(xiě)成一個(gè)model。其中我們使用了c語(yǔ)言的讀寫(xiě)方法,搞了一星期, 挖了很多坑,最終都鏟平了。下面列舉出若干有用的知識(shí)。
1.fwrite,fread VS fprintf,fscanf的區(qū)別
fwrite,fread 讀寫(xiě)的時(shí)候,我發(fā)現(xiàn)不管使用FILE* pFile = fopen(“myfile.bin”, “wb”);無(wú)論是使用“wb”還是“w”,最后寫(xiě)出的數(shù)據(jù)均是亂碼,所以?xún)?nèi)容是不可讀的。但是安全性好,我們后來(lái)就使用fwrite,fread 讀寫(xiě)model.而 fprintf,fscanf是可視的。
2. 使用fwrite,fread 讀寫(xiě)文件的時(shí)候,切記注意變量的格式,舉個(gè)例子:
我讀入一個(gè)double類(lèi)型數(shù)據(jù),但是想以float型寫(xiě)入文件,然后再以float讀入,發(fā)現(xiàn)讀出的數(shù)據(jù)b是錯(cuò)的。原因在于一個(gè)double類(lèi)型,讀入sizeof(float)個(gè)字節(jié),會(huì)發(fā)生截?cái)?#xff0c;所以數(shù)據(jù)是錯(cuò)誤的。應(yīng)該改為:
#include <stdio.h> #include <string.h>int main() {FILE * pFile;pFile = fopen("myfile.bin", "wb");double a = 5.1615665161;float atemp = a;fwrite(&atemp, sizeof(float), 1, pFile);rewind(pFile);pFile = fopen("myfile.bin", "rb");double b ;float btemp;fread(&btemp, sizeof(float), 1, pFile);b = btemp;return 0; }也就是必須堅(jiān)持以原數(shù)據(jù)的原有格式去讀寫(xiě)。
3. 多次打開(kāi)文件,寫(xiě)數(shù)據(jù)的方式
一般我們使用:
a即附加的意思。讀的時(shí)候,如果我們先讀入部分?jǐn)?shù)據(jù),再將文件關(guān)掉,然后再打開(kāi)文件,繼續(xù)讀下一行的數(shù)據(jù),可以使用
long offset = ftell(fp);
先記下之前讀文本的指針位置偏移量,然后下一次打卡文件,將文件指針從頭偏移offset量即可。
總結(jié)
以上是生活随笔為你收集整理的fwrite,fread and fprintf,fscanf的一些使用体会的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: NIO核心框架介绍
- 下一篇: Cisco设备基础命令