在 C 語言中,變量的地址往往都是編譯系統(tǒng)自動分配的,對我們用戶來說,我們是不知道某個變量的具體地址的。所以我們定義一個指針變量 p,把普通變量 a 的地址直接送給指針變量 p 就是 p = &a;這樣的寫法。
對于指針變量 p 的定義和初始化,一般有兩種方式,這兩種方式,初學者很容易混淆,因此這個地方?jīng)]別的方法,就是死記硬背,記住即可。
方法1:定義時直接進行初始化賦值。
unsigned char a;
unsigned char *p = &a;
方法2:定義后再進行賦值。
unsigned char a;
unsigned char *p;
p = &a;
大家仔細看會看出來這兩種寫法的區(qū)別,它們都是正確的。我們在定義的指針變量前邊加了個,這個p 就代表了這個 p 是個指針變量,不是個普通的變量,它是專門用來存放變量地址的。此外,我們定義*p 的時候,用了 unsigned char 來定義,這里表示的是這個指針指向的變量類型是 unsigned char 型的。
指針變量似乎比較好理解,大家也能很容易就聽明白。但是為什么很多人弄不明白指針呢?因為在 C 語言中,有一些運算和定義,他們是有區(qū)別的,很多同學就是沒弄明白它們的區(qū)別,指針就始終學不好。這里我要重點強調(diào)兩個區(qū)別,只要把這兩個區(qū)別弄明白了,起碼指針變量這部分就不是問題了。這兩個重點現(xiàn)在大家死記硬背,直接記住即可,靠理解有可能混淆概念。
第一個重要區(qū)別:指針變量 p 和普通變量 a 的區(qū)別。
我們定義一個變量 a,同時也可以給變量 a 賦值 a = 1,也可以賦值 a = 2。
我們定義一個指針變量 p,另外還定義了一個普通變量 a= 1,普通變量 b=2,那么這個指針變量可以指向 a 的地址,也可以指向 b 的地址,可以寫成 p = &a,也可以寫成 p = &b,但就是不能寫成 p = 1 或者 p = 2 或者 p = a,這三種表達方式都是錯的。
因此這個地方,不要看到定義*p 的時候前邊有個 unsigned char 型,就錯誤的賦值 p=1,這個只是說明 p 指向的變量是這個 unsigned char 類型的,而 p 本身,是指針變量,不可以給它賦值普通的值或者變量,后邊我們會直接把指針變量稱之為指針,大家要注意一下這個小細節(jié)。
前邊這個區(qū)別似乎比較好理解,還有第二個重要區(qū)別,一定要記清楚。
第二個重要區(qū)別:定義指針變量 p 和取值運算 p 的區(qū)別。
“*”這個符號,在我們的 C 語言有三個用法,第一個用法很簡單,乘法操作就是用這個符號,這里就不講了。
第二個用法,是定義指針變量的時候用的,比如 unsigned char p,這個地方使用“”代表的意思是 p 是一個指針變量,而非普通的變量。
還有第三種用法,就是取值運算,和定義指針變量是完全兩碼事,比如:
unsigned char a = 1;
unsigned char b = 2;
unsigned char *p;
p = &a;
b = *p;
這樣兩步運算完了之后,b 的值就成了1了。在這段代碼中,&a 表示取 a 這個變量的地址,把這個地址送給 p 之后,再用 p 運算表示的是取指針變量 p 指向的地址的變量的值,又把這個值送給了 b,最終的結(jié)果相當于 b=a。同樣是 p,放在定義的位置就是定義指針變量,放在執(zhí)行代碼中就是取值運算。
這兩個重要區(qū)別,大家可以反復閱讀三四遍,把這兩個重要區(qū)別弄明白,指針的大門就順利的踏進去一只腳了。至于詳細的用法,我們后邊用得多了就會慢慢熟悉起來了。