測試函數(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
這個(gè)程序的輸出是:
65 B 67 D
9
從這個(gè)程序發(fā)現(xiàn)scanf家族對這個(gè)函數(shù)所作的事情就是將所有格式的變量以
一個(gè)文本的形式輸出到我們指定的地方,不論是數(shù)組還是文件;
sprintf(value,”%d %c %d %c”,a[0],a[1],a[2],a[3]);
這個(gè)調(diào)用,
即先讀到一個(gè)%d,對應(yīng)a[0]是65,
就在value[0]放入6的ascii碼然后在value[1]存入5的ascii碼,下一個(gè)是空格就在value[2]保存空格的ascii
下一個(gè)是%c匹配a[2]就把a(bǔ)[2]的值直接當(dāng)作一個(gè)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相似:第一個(gè)參數(shù)類型是%d即讀入一個(gè)整形賦值給a;
用一個(gè)空格分開123和a
就是為了讓程序了解空格前1,2,3這三個(gè)字符都屬于變量a;
所以a的值是經(jīng)過:
(‘1’-‘0’) * 100 * +(‘2’-‘0’) * 10 + (‘3’-‘0’) * 1得到的;
得出結(jié)論:
理解二進(jìn)制保存的方式和文本保存的方式:
在linux下:所有的文件都是按文本的方式存儲和讀取的,所以所有的文件打開的時(shí)候默認(rèn)為是文本文件,當(dāng)我們保存一些數(shù)字進(jìn)入文檔時(shí),只能按字節(jié)翻譯數(shù)字為對應(yīng)的符號,這就是為什么打開一個(gè)可執(zhí)行文件時(shí)會出現(xiàn)亂碼的情況.因?yàn)榭蓤?zhí)行文件都是一些二進(jìn)制機(jī)器碼.
文件存儲是一個(gè)個(gè)字節(jié)存儲的,而且存儲的都是一個(gè)二進(jìn)制數(shù),scanf和print只是用了字符數(shù)字互轉(zhuǎn)的方法對文件或者數(shù)組元素
進(jìn)行取放的.
對于格式化輸入輸出函數(shù)
文件存儲是一個(gè)個(gè)字節(jié)存儲的,而且存儲的都是一個(gè)二進(jìn)制數(shù),scanf和print只是用了字符數(shù)字互轉(zhuǎn)的方法對文件或者數(shù)組元素
進(jìn)行取放的.
即:scanf按格式把 ascii碼->所需格式保存至變量.
printf按格式把 某些格式變量->ascii碼
方便文本軟件按ascii碼顯示內(nèi)容
至于非格式化io,即不格式化直接將數(shù)據(jù)原封不動一個(gè)個(gè)字節(jié)輸出輸入;
fgetc和getchar;fputc和putchar:即一個(gè)個(gè)字節(jié)輸入輸出;
fgets和gets;fputs和puts:即一次一行’\n’一個(gè)個(gè)字節(jié)輸入輸出;
fread和fwrite:即一次可控字節(jié)數(shù)輸入輸出;(直接忽略變量類型直接對內(nèi)存按字節(jié)操作)