格式化io與非格式化io的對比理解
測試函數(shù)1
#include
#include
int main()
{
int a[5]={65,66,67,68};
char value[10],i;
FILE *pf;
if(!(pf = fopen("printf.txt","w+")))
{
perror("open file:");
return -1;
}
fprintf(pf,"%d %c %d %c",a[0],a[1],a[2],a[3]);
sprintf(value,"%d %c %d %c",a[0],a[1],a[2],a[3]);
puts(value);
printf("%d",strlen(value));
fclose(pf);
return 0;
}123456789101112131415161718192021222324
這個程序的輸出是:
65 B 67 D
9
從這個程序發(fā)現(xiàn)scanf家族對這個函數(shù)所作的事情就是將所有格式的變量以
一個文本的形式輸出到我們指定的地方,不論是數(shù)組還是文件;
sprintf(value,”%d %c %d %c”,a[0],a[1],a[2],a[3]);
這個調(diào)用,
即先讀到一個%d,對應a[0]是65,
就在value[0]放入6的ascii碼然后在value[1]存入5的ascii碼,下一個是空格就在value[2]保存空格的ascii
下一個是%c匹配a[2]就把a[2]的值直接當作一個ascii碼存入value[3],以此類推….
所以最后得到字符串長度為9
測試程序2
#include
int main()
{
FILE *fp;
int a;
char b,c[100];
if(!(fp = fopen("scanf.txt","r+")))
{
perror("opend file:");
return -1;
}
fscanf(fp,"%d %c %s",&a,&b,c);
printf("%d %d %d\n",(int)a,(int)b,(int)*c);
fclose(fp);
return 0;
}12345678910111213141516171819202122
scanf.txt的內(nèi)容是:
123 a abc
輸出是:
123 97 97
scanf家族的原理也和printf相似:第一個參數(shù)類型是%d即讀入一個整形賦值給a;
用一個空格分開123和a
就是為了讓程序了解空格前1,2,3這三個字符都屬于變量a;
所以a的值是經(jīng)過:
(‘1’-‘0’) * 100 * +(‘2’-‘0’) * 10 + (‘3’-‘0’) * 1得到的;
得出結(jié)論:
理解二進制保存的方式和文本保存的方式:
在linux下:所有的文件都是按文本的方式存儲和讀取的,所以所有的文件打開的時候默認為是文本文件,當我們保存一些數(shù)字進入文檔時,只能按字節(jié)翻譯數(shù)字為對應的符號,這就是為什么打開一個可執(zhí)行文件時會出現(xiàn)亂碼的情況.因為可執(zhí)行文件都是一些二進制機器碼.
文件存儲是一個個字節(jié)存儲的,而且存儲的都是一個二進制數(shù),scanf和print只是用了字符數(shù)字互轉(zhuǎn)的方法對文件或者數(shù)組元素
進行取放的.
對于格式化輸入輸出函數(shù)
文件存儲是一個個字節(jié)存儲的,而且存儲的都是一個二進制數(shù),scanf和print只是用了字符數(shù)字互轉(zhuǎn)的方法對文件或者數(shù)組元素
進行取放的.
即:scanf按格式把 ascii碼->所需格式保存至變量.
printf按格式把 某些格式變量->ascii碼
方便文本軟件按ascii碼顯示內(nèi)容
至于非格式化io,即不格式化直接將數(shù)據(jù)原封不動一個個字節(jié)輸出輸入;
fgetc和getchar;fputc和putchar:即一個個字節(jié)輸入輸出;
fgets和gets;fputs和puts:即一次一行’\n’一個個字節(jié)輸入輸出;
fread和fwrite:即一次可控字節(jié)數(shù)輸入輸出;(直接忽略變量類型直接對內(nèi)存按字節(jié)操作)
編輯:admin 最后修改時間:2018-05-18