字串的格式化輸入和輸出
阿新 • • 發佈:2021-11-19
C語言學習中的筆記
char型別陣列和NULL字元
C語言沒有專門用於儲存字串的變數型別,字串都被儲存在char型別的陣列上,陣列由連續的儲存單元組成,字串中的字元被儲存在相鄰的儲存單元中
strlen()函式
sizeof()以位元組為單位給出物件的大小,strlen()給出字串的字元長度,string.h標頭檔案包含了字串函式的宣告,記得要引入該標頭檔案
常量和C前處理器
#define =
const限定符
物件的型別如果採用了限定符 const,則該物件就是常量。在定義該物件之後,程式無法修改它。
資料型別轉換
- 自動型別轉換
-
將一種型別的資料賦值給另外一種型別的變數時就會發生自動型別轉換,
float f = 100;
100 是 int 型別的資料,需要先轉換為 float 型別才能賦值給變數 f。 -
在不同型別的混合運算中,編譯器也會自動地轉換資料型別,將參與運算的所有資料先轉換為同一種類型,然後再進行計算。轉換的規則如下
- 轉換按資料長度增加的方向進行,以保證數值不失真,或者精度不降低。例如,int 和 long 參與運算時,先把 int 型別的資料轉成 long 型別後再進行運算。
- 所有的浮點運算都是以雙精度進行的,即使運算中只有 float 型別,也要先轉換為 double 型別,才能進行運算。
- char 和 short 參與運算時,必須先轉換成 int 型別。
- 強制型別轉換
自動型別轉換是編譯器根據程式碼的上下文環境自行判斷的結果,有時候並不是那麼“智慧”,不能滿足所有的需求。如果需要,程式設計師也可以自己在程式碼中明確地提出要進行型別轉換,這稱為強制型別轉換。
(type_name) expression
(float) a; //將變數 a 轉換為 float 型別 (int)(x+y); //把表示式 x+y 的結果轉換為 int 整型 (float) 100; //將數值 100(預設為int型別)轉換為 float 型別
下面是一個需要強制轉化的例子
天下之大,又何止南北呢?int main(){ int sum = 103; //總數 int count = 7; //數目 double average; //平均數 average = (double) sum / count; printf("Average is %lf!\n", average); return 0; }``` sum 和 count 都是 int 型別,如果不進行干預,那麼sum / count的運算結果也是 int 型別,小數部分將被丟棄;雖然是 average 是 double 型別,可以接收小數部分,但是心有餘力不足,小數部分提前就被“閹割”了,它只能接收到整數部分,這就導致除法運算的結果嚴重失真。 既然 average 是 double 型別,為何不充分利用,儘量提高運算結果的精度呢?為了達到這個目標,我們只要將 sum 或者 count 其中之一轉換為 double 型別即可。上面的程式碼中,我們將 sum 強制轉換為 double 型別,這樣sum / count的結果也將變成 double 型別,就可以保留小數部分了,average 接收到的值也會更加精確。 在這段程式碼中,有兩點需要注意: 對於除法運算,如果除數和被除數都是整數,那麼運算結果也是整數,小數部分將被直接丟棄;如果除數和被除數其中有一個是小數,那麼運算結果也是小數。這一點已在《C語言加減乘除運算》中進行了詳細說明。 ( )的優先順序高於/,對於表示式(double) sum / count,會先執行(double) sum,將 sum 轉換為 double 型別,然後再進行除法運算,這樣運算結果也是 double 型別,能夠保留小數部分。注意不要寫作(double) (sum / count),這樣寫運算結果將是 3.000000,仍然不能保留小數部分。 - 型別轉換隻是臨時性的 無論是自動型別轉換還是強制型別轉換,都只是為了本次運算而進行的臨時性轉換,轉換的結果也會儲存到臨時的記憶體空間,不會改變資料本來的型別或者值。請看下面的例子: #include <stdio.h> int main(){ double total = 400.8; //總價 int count = 5; //數目 double unit; //單價 int total_int = (int)total; unit = total / count; printf("total=%lf, total_int=%d, unit=%lf\n", total, total_int, unit); return 0; }```