程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C >> C語言基礎知識 >> C 語言基礎教程(我的C之旅開始了)[三]

C 語言基礎教程(我的C之旅開始了)[三]

編輯:C語言基礎知識

7. 第三個 C 程序
首先請看下面這個小程序,試著自己編譯運行一下。如果不懂怎麼編譯,請點擊下面的超鏈接:
      編譯器使用方法
    編譯器Dev-C++下載&使用教程

      /* circle.c  --  計算圓的面積 */

      #include <stdio.h>

      int main( void )
      {
          float radius;    /* 圓的半徑 */

          printf( "Please enter the radius: " );
          /* 獲取用戶輸入 */
          scanf( "%f", &radius );
          /* 圓面積計算公式:圓周率 * 半徑的平方 */
          printf( "The area of the circle is: %.3f\n", 3.14 * radius * radius );

          printf( "Press ENTER to quit..." );
          getchar();
          getchar();    
          return 0;
      }

     “enter the radius”的意思是:輸入圓的半徑,然後按回車(Enter)。這個程序要求我們輸入數字,例如:15、31.6。不要輸入字母,例如:abc、t156。輸入字母將導致程序出錯!以後我們會學如何處理這種錯誤,不過現在還是老老實實地輸入數字吧!當然,您也可以試著輸入字母,看看到底會發生什麼事情。

    下面我們來仔細講解這個程序的知識點。

    1. 程序的第 7 行,我們使用float聲明了一個名為 radius的變量float代表的數據類型是浮點型,也就是小數。在以往的程序中,我們都是使用 int 來聲明變量。int 代表整型,也就是整數。用 int 聲明的變量只能存儲整數;而用 float 聲明的變量可以存儲小數。

    2. 為了接受用戶輸入,我們需要使用 scanf函數。和 printf一樣,scanf 也是標准庫裡定義的函數,我們稱這樣的函數為標准函數。和printf一樣,scanf的函數原型也位於標准頭文件 stdio.h 裡。占位符 %f 的作用是命令 scanf 函數讀取浮點數;&radius 告訴 scanf 用讀取到的浮點數給變量 radius 賦值。其中 & 必不可少,否則程序將會出錯。& 在這裡是取址運算符,用於獲取變量 radius 的內存地址,從而告訴 scanf 將讀取到的浮點數存儲到那個地址所指示的內存空間,也就達到了給 radius 賦值的目的。如果您看不懂上面這些內容,沒什麼關系,真的,只要您可以記住就好了。以後,我們將更深入地學習這些知識。

    3. radius 是浮點型變量,3.14 默認是雙精度浮點型double恆量,所以表達式 3.14 * radius * radius 的結果是一個雙精度浮點數。這裡看不懂也沒關系,以後我們會詳細學習。

    4. 要顯示浮點型數據,我們需要使用占位符 %f%d 是用於顯示整數的,如果我們將第二個 printf 中的 %.3f 換成 %d,那麼輸出會不正常。.3 的作用是告訴 printf 只輸出小數點後 3 位。我們也可以改成 .2 或者 .0 等。.0 代表不輸出小數部分。

    5. 程序最後連續用了兩個 getchar 函數,在此起的作用是等待用戶輸入回車,然後才退出程序。getchar 也是標准函數,它的函數原型同樣也是位於標准頭文件 stdio.h 中,它的作用是讀取用戶輸入的一個字符。具體為什麼這裡要用兩個 getchar 我們以後再說。

8. 錯誤(Error)和警告(Warning)

 

    到目前為止,我們已經寫了好幾個 C 程序。也許有些人在編譯程序的時候,編譯器說程序那裡那裡有錯誤error),並且也不把程序編譯成可執行文件。編譯器報錯則說明我們的程序存在錯誤!漏寫分號(;)或者沒寫收大括號 } 等等都會導致編譯器報錯。

    也許有些人寫的程序可以通過編譯,但是編譯器同時也給出了一些警告warning)。編譯器報警則說明我們寫的代碼符合 C 語言語法,但是那些代碼所起的效果可能和我們所期待的不同。

    作為程序員,我們應該仔細閱讀出錯信息和警告。從那些信息中,我們可以了解到程序出錯的地在哪裡,從而將錯誤改正。改錯時,如果在編譯器所說的出錯的一行中未發現錯誤,就需要看看上一行是否有錯誤

9. 恆量(常量)和變量

 

     有些數據的值在程序運行之前就已經確定了,並且在程序運行過程中都不能改變,這樣的數據稱為恆量,或者常量。例如:'a' 是字符常量,"a" 是字符串常量,123 是整型常量,123.45 是雙精度浮點型常量。以上數據的值都是在程序運行之前就已經確定了的,並且不能改變,所以它們都是恆量。

    在程序運行過程中可以改變的數據,稱為變量。例如:
           double pi = 3.14;
上面語句中,pi 是變量,因為我們在這個語句後面可以不斷地改變 pi 的值。例如:
           pi = 3.1415;
           scanf( "%lf", &pi );
上面兩個語句都可以改變 pi 的值。上面的代碼中,3.14 和 3.1415 都是雙精度(double)浮點型常量。%lf 是中的 l小寫的英文字母 L,這裡一定要用小寫。%lf 的作用是告訴 scanf 函數,&pi 是一個雙精度浮點型指針(double *)。而 %Lf 的意思是,&pi 是加長型雙精度浮點型指針(long double *)。因為 pi 是雙精度浮點型變量,所以 &pi 是雙精度浮點型指針,故而我們應該用%lf

    恆量變量的不同之處在於:恆量的值是恆定不變的,而變量的值可以通過賦值等方法改變。

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