【寫在開頭:】 『 函數:從名稱上來說是一個數學名詞,是萊布尼茲在1694年開始使用的,用來描述跟曲線相關的一個量,如曲線的斜率或者曲線上的某一點。 在面向過程的C語言中,用來完成一些特定的功能。 而在OC或Java等一些面向對象的語言中,稱之為方法。表示某個對象所具有的行為。 方法也好,函數也罷, ...
兩個庫函數
--------------------------
--1-- printf函數--2-- scanf函數--------------------------
【寫在開頭:】
『
函數:從名稱上來說是一個數學名詞,是萊布尼茲在1694年開始使用的,用來描述跟曲線相關的一個量,如曲線的斜率或者曲線上的某一點。
在面向過程的C語言中,用來完成一些特定的功能。
而在OC或Java等一些面向對象的語言中,稱之為方法。表示某個對象所具有的行為。
方法也好,函數也罷,首先要明白他是乾什麼的?
簡單的說--> C語言函數用來完成程式的功能
{
C語言不但提供了豐富的庫函數,還允許用戶定義自己的函數。每個函數都是一個可以重覆使用的模塊,通過模塊間的相互調用,有條不紊地實現複雜的功能。可以說C程式的全部工作都是由各式各樣的函數完成的,所以也把C語言稱為函數式語言。可以說C程式的全部工作都是由各式各樣的函數完成的,所以C語言也稱為函數式語言。
標準C語言(ANSI C)共定義了15 個頭文件,稱為“C標準庫”,所有的編譯器都必須支持,如何正確並熟練的使用這些標準庫,可以反映出一個程式員的水平。
- 合格程式員:<stdio.h>、<ctype.h>、<stdlib.h>、<string.h>
- 熟練程式員:<assert.h>、<limits.h>、<stddef.h>、<time.h>
- 優秀程式員:<float.h>、<math.h>、<error.h>、<locale.h>、<setjmp.h>、<signal.h>、<stdarg.h>
以上各類函數不僅數量多,而且有的還需要硬體知識才能使用。
還應該指出的是,在C語言中,所有的函數定義,包括主函數main在內,都是平行的。也就是說,在一個函數的函數體內,不能再定義另一個函數,即不能嵌套定義。但是函數之間允許相互調用,也允許嵌套調用。習慣上把調用者稱為主調函數,被調用者稱為被調函數。函數還可以自己調用自己,稱為遞歸調用。
main 函數是主函數,它可以調用其它函數,而不允許被其它函數調用。因此,C程式的執行總是從main函數開始,完成對其它函數的調用後再返回到main函數,最後由main函數結束整個程式。一個C源程式必須有、也只能有一個主函數main。(此處引自http://c.biancheng.net/cpp/html/55.html)
}
』
--1-- printf函數
1.1 printf 函數的介紹
printf 是一個標準的輸出庫函數,能夠以精確的格式輸出程式的運算結果。
格式:printf(“格式控制字元串”,輸出項列表(變數列表));
輸出項列表:必須與格式控制符在類型和數量上完全對應。當有多個輸出項時,各個輸出項之間用“,”隔開。
1.2 格式控制字元串:
規定數據輸入的格式,由格式控制符和普通字元組成,和%一起使用,用來說明輸入數據的數據類型(格式字元)。
需要接受數據的變數地址,輸入項與格式控制字元串在類型和數量上要對應,當有多個輸入項時,各個地址名之間用”,“隔開,輸入格式和變數類型要保持一致。
使用說明:
%d 輸出一個10進位的整數
%f 輸出一個實數類型數據(不能輸出整型數據),預設輸出6位小數
%c 輸出一個字元
%s輸出一個字元串
%o把一個數以八進位的格式輸出
%x把一個數以十六進位的格式輸出
%p 輸出記憶體地址
%ld:輸入輸出double(實型)類型的實型數值
%u:輸入輸出unsigned(無符號)類型的數值
1.3 %f輸出精度的問題
float f1 = 3.1415926f; float a = 1111.111111; float b = 2222.22222; printf("f1 = %f\n",f1); //-->3.1415923 預設輸出小數點後6位 /* 註意,%f列印出來後,精度小數點後6位,有效數字是7位所以最後的數“5”是個無效數字。 這裡使用floalt是打不出小數點後的第七位的,有效數字後的數字是無效的。 */ printf("f1=%.7f\n",f1); //-->3.1415925 printf("a + b= %f\n", a+b); //-->3333.333252 有效位數(7位)之後的數字都是無效的。%f輸出精度示例
解決方案
要列印更大精度的就只有使用double類型
double預設的是精度小數點後7位,有效數字是15位。
有效位數是小數點前面和後面的位數總和,不包含小數點。
1.4 printf 函數使用註意事項
1)域寬問題
1)%md問題(設置域寬(列數)問題)
m為一個數字,可為正,也可以為負。
如果要輸出的數的位數 >域寬m -->則按照數據的實際位數輸出
如果位數 < 域寬m -->則要補空格
printf("%3d\n", 18888); //位數大於域寬 原樣輸出 printf ("%5d\n",10); // 10 (1前面補了3個空格)View Code
m的取值有兩種(正數和負數):
m>0 從左側補空格
m <0 從右側開始補空格
2)%0md(遍歷圖片時很常用)
%0md是%md的升級版,表示不足部分補0
printf("%02d\n", 1); //01
2)轉義字元
printf("\\\n"); //-->\ printf("%%\n"); //-->% printf("\"\n"); //-->" printf("\t製表符\n"); //製表符
--2--scanf函數
2.1 介紹
sacnf函數是阻塞式函數,原型包含在標準輸入輸出頭文件<stdio.h>中,用於接收鍵盤輸入的內容。
格式:scanf("格式控制字元串",輸入項的地址列表);
scanf常見的格式控制符:
2.2 作用
從鍵盤接受輸入的內容,保存到指定的變數中
2.3 sanf函數註意事項
1)scanf函數當遇到回車的時候,結束執行
2)接受單個變數值時,在輸入值之前,如果輸入了空格、回車、tab 、這些都會被忽略。
3)非法的格式輸入
3.1)輸入用逗號”,“隔開
輸入:12,45-->age=12, 則num未賦值
3.2)混合空格輸入
scanf("%d,%c,%d",&a,&ch,&b); //輸入:12,a,45 printf("%d,%c,%d\n",a,ch,b); //與預計的輸出不同 實際輸出-->12, ,-1View Code
解決方案:需原樣輸入
4)關於*號的使用
int a = -1, b = -1; printf("請輸入a和b的值:\n"); //%*d 跳過一個整數,%*c忽略一個字元 scanf("%d%*d%d",&a,&b); //輸入 1990 11 20 printf("a = %d, b = %d\n", a, b); //a = 1990, b = 20View Code
2.4 輸入緩存區
當用戶輸入內容後,輸入內容會被存到scanf的輸入緩存區,然後scanf會根據格式控制的字元的要求,從輸入緩衝區依次取它想要的內容
如果從緩衝區中取得內容和指定的格式要求一致,則把值賦給變數
如果格式不一致,則不修改變數的值
【寫在結尾:】
『
在網上看到一張圖:
想到了自己曾經的Java之路。一路艱辛,一路跌跌撞撞,卻也有一路的風景。
直到有一天,到了個十字路口,沒有紅綠燈。於是我茫然的在岔口徘徊,我知道,我始終是要做一個選擇,可是我這時明白,有時選擇太多,卻也不見得是一件的好事。
如果是你,我想,你會往前走。
如果是你,我想,你會停下來。
如果是你,我想,你會往回走。
而我,卻不是你。
』