C 變數

C 變數

變數其實只不過是程式可操作的儲存區的名稱。C 中每個變數都有特定的型別,型別決定了變數儲存的大小和佈局,該範圍內的值都可以儲存在記憶體中,運算子可應用於變數上。

變數的名稱可以由字母、數字和下劃線字元組成。它必須以字母或下劃線開頭。大寫字母和小寫字母是不同的,因為 C 是大小寫敏感的。基於前一章講解的基本型別,有以下幾種基本的變數型別:

型別描述
char通常是一個位元組(八位), 這是一個整數型別。
int整型,4 個位元組,取值範圍 -2147483648 到 2147483647。
float

單精度浮點值。單精度是這樣的格式,1位符號,8位指數,23位小數。

double

雙精度浮點值。雙精度是1位符號,11位指數,52位小數。

void表示型別的缺失。

C 語言也允許定義各種其他型別的變數,比如列舉、指標、陣列、結構、共用體等等,這將會在後續的章節中進行講解,本章節我們先講解基本變數型別。

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),其他所有變數的初始值是未定義的。

C 中的變數宣告

變數宣告向編譯器保證變數以指定的型別和名稱存在,這樣編譯器在不需要知道變數完整細節的情況下也能繼續進一步的編譯。變數宣告只在編譯時有它的意義,在程式連線時編譯器需要實際的變數宣告。

變數的宣告有兩種情況:

  • 1、一種是需要建立儲存空間的。例如:int a 在宣告的時候就已經建立了儲存空間。
  • 2、另一種是不需要建立儲存空間的,通過使用extern關鍵字宣告變數名而不定義它。 例如:extern int a 其中變數 a 可以在別的檔案中定義的。
  • 除非有extern關鍵字,否則都是變數的定義。
extern int i; //宣告,不是定義
int i; //宣告,也是定義

例項

嘗試下面的例項,其中,變數在頭部就已經被宣告,但是定義與初始化在主函式內:

例項

#include <stdio.h> // 函式外定義變數 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 關鍵字的宣告即可。

addtwonum.c 檔案程式碼:

#include <stdio.h> /*外部變數宣告*/ extern int x ; extern int y ; int addtwonum() { return x+y; }

test.c 檔案程式碼:

#include <stdio.h> /*定義兩個全域性變數*/ 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 中的左值(Lvalues)和右值(Rvalues)

C 中有兩種型別的表示式:

  1. 左值(lvalue):指向記憶體位置的表示式被稱為左值(lvalue)表示式。左值可以出現在賦值號的左邊或右邊。
  2. 右值(rvalue):術語右值(rvalue)指的是儲存在記憶體中某些地址的數值。右值是不能對其進行賦值的表示式,也就是說,右值可以出現在賦值號的右邊,但不能出現在賦值號的左邊。

變數是左值,因此可以出現在賦值號的左邊。數值型的字面值是右值,因此不能被賦值,不能出現在賦值號的左邊。下面是一個有效的語句:

int g = 20;

但是下面這個就不是一個有效的語句,會生成編譯時錯誤:

10 = 20;