程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C語言-兩個庫函數,c語言庫函數

C語言-兩個庫函數,c語言庫函數

編輯:關於C語言

C語言-兩個庫函數,c語言庫函數


兩個庫函數

--------------------------

--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, ,-1 View 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 = 20 View Code

 

2.4 輸入緩存區

當用戶輸入內容後,輸入內容會被存到scanf的輸入緩存區,然後scanf會根據格式控制的字符的要求,從輸入緩沖區依次取它想要的內容

如果從緩沖區中取得內容和指定的格式要求一致,則把值賦給變量

如果格式不一致,則不修改變量的值

 

 

 

 

 

 

 

 【寫在結尾:】

在網上看到一張圖:

想到了自己曾經的Java之路。一路艱辛,一路跌跌撞撞,卻也有一路的風景。

直到有一天,到了個十字路口,沒有紅綠燈。於是我茫然的在岔口徘徊,我知道,我始終是要做一個選擇,可是我這時明白,有時選擇太多,卻也不見得是一件的好事。

如果是你,我想,你會往前走。

如果是你,我想,你會停下來。

如果是你,我想,你會往回走。

而我,卻不是你。

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved