變數其實只不過是程式可操作的儲存區的名稱。c 中每個變數都有特定的型別,型別決定了變數儲存的大小和布局,該範圍內的值都可以儲存在記憶體中,運算子可應用於變數上。
變數的名稱可以由字母、數字和下劃線字元組成。它必須以字母或下劃線開頭。大寫字母和小寫字母是不同的,因為 c 是大小寫敏感的。基於基本型別,有以下幾種基本的變數型別:
型別描述
char
通常是乙個位元組(八位)。這是乙個整數型別。
int對機器而言,整數的最自然的大小。
float
單精度浮點值。單精度是這樣的格式,1位符號,8位指數,23位小數。
雙精度浮點值。雙精度是1位符號,11位指數,52位小數。
表示型別的缺失。
c 語言也允許定義各種其他型別的變數,比如列舉、指標、陣列、結構、共用體等等,這將會在後續的章節中進行講解,本章節我們先講解基本變數型別。
變數定義就是告訴編譯器在何處建立變數的儲存,以及如何建立變數的儲存。變數定義指定乙個資料型別,幷包含了該型別的乙個或多個變數的列表,如下所示:
type variable_list;
在這裡,type必須是乙個有效的 c 資料型別,可以是 char、w_char、int、float、double 或任何使用者自定義的物件,variable_list可以由乙個或多個識別符號名稱組成,多個識別符號之間用逗號分隔。下面列出幾個有效的宣告:
int i, j, k;
char c, ch;
float f, salary;
double d;
行int i, j, k;宣告並定義了變數 i、j 和 k,這指示編譯器建立型別為 int 的名為 i、j、k 的變數。
變數可以在宣告的時候被初始化(指定乙個初始值)。初始化器由乙個等號,後跟乙個常量表示式組成,如下所示:
type variable_name = value;
下面列舉幾個例項:
extern int d = 3, f = 5; // d 和 f 的宣告與初始化
int d = 3, f = 5; // 定義並初始化 d 和 f
byte z = 22; // 定義並初始化 z
char x = 'x'; // 變數 x 的值為 'x'
不帶初始化的定義:帶有靜態儲存持續時間的變數會被隱式初始化為 null(所有位元組的值都是 0),其他所有變數的初始值是未定義的。
變數宣告向編譯器保證變數以指定的型別和名稱存在,這樣編譯器在不需要知道變數完整細節的情況下也能繼續進一步的編譯。變數宣告只在編譯時有它的意義,在程式連線時編譯器需要實際的變數宣告。
變數的宣告有兩種情況:
extern int i; //宣告,不是定義
int i; //宣告,也是定義
嘗試下面的例項,其中,變數在頭部就已經被宣告,但是定義與初始化在主函式內:
#include // 函式外定義變數 x 和 y
int x;int y;int addtwonum()
{ // 函式內宣告變數 x 和 y 為外部變數
extern int x;
extern int y; // 給外部變數(全域性變數)x 和 y 賦值
x = 1; y = 2;
return x+y;
int main()
int result; // 呼叫函式 addtwonum
result = addtwonum();
printf("result 為: %d",result);
return 0;
當上面的**被編譯和執行時,它會產生下列結果:
result 為: 3
如果需要在乙個原始檔中引用另外乙個原始檔中定義的變數,我們只需在引用的檔案中將變數加上 extern 關鍵字的宣告即可。
#include /*外部變數宣告*/
extern int x ;
extern int y ;
int addtwonum()
return x+y;
#include /*定義兩個全域性變數*/
int x=1;int y=2;
int addtwonum();
int main(void)
int result;
result = addtwonum();
printf("result 為: %d\n",result);
return 0;
當上面的**被編譯和執行時,它會產生下列結果:
$ gcc addtwonum.c test.c -o main
$ ./main
result 為: 3
c 中有兩種型別的表示式:
左值(lvalue):指向記憶體位置的表示式被稱為左值(lvalue)表示式。左值可以出現在賦值號的左邊或右邊。
右值(rvalue):術語右值(rvalue)指的是儲存在記憶體中某些位址的數值。右值是不能對其進行賦值的表示式,也就是說,右值可以出現在賦值號的右邊,但不能出現在賦值號的左邊。
變數是左值,因此可以出現在賦值號的左邊。數值型的字面值是右值,因此不能被賦值,不能出現在賦值號的左邊。下面是乙個有效的語句:
int g = 20;
但是下面這個就不是乙個有效的語句,會生成編譯時錯誤:
10 = 20;
C語言基本知識
c語言中提供了一組標準函式,用來解決常見問題 每個標準函式有自己的名字 為了使用這個標準函式需要把 stdio.h 檔案的內容合併到原始檔中 為了使用標準函式需要編寫函式呼叫語句 n 表示換行,可以把後面的內容列印在下一行中 可以採用佔位符列印編寫程式的時候還不知道的數字 d 佔位符和整數型別字配對...
C語言基本知識3
一 程式設計規範 軟體程式設計規範作用 增強程式可讀性 增強 復用性 增強 維護性 軟體程式設計規範總則 排版注釋 識別符號命名 二 函式引數順序點 函式呼叫過程中,變數值發生變化的位置 點 稱為函式引數 順序點 順序點一般位於 1 語句結束時值改變 k 2 k k k 2 等運算子 3 函式引數傳...
C 基本知識
內聯函式 在c 98的標準下為63個關鍵字 1.普通的命名空間 namespace n1 n1為命名空間的名稱 2.命名空間可以巢狀 namespace n2 namespace n3 3.同乙個工程中允許存在多個相同名稱的命名空間,編譯器最後會合成同乙個命名空間中。1.加命名空間名稱及作用域限定符...