糯米文學吧

位置:首頁 > 計算機 > C語言

C語言中指針的用法介紹

C語言2.45W

指針是一個特殊的變量,它裏面存儲的數值被解釋成為內存裏的一個地址。要搞清一個指針需要搞清指針的四方面的內容:指針的類型,指針所指向的類型,指

C語言中指針的用法介紹

針的值或者叫指針所指向的內存區,還有指針本身所佔據的內存區。讓我們分別説明。

先聲明幾個指針放着做例子:

例一:

(1)int *ptr;

(2)char *ptr;

(3)int **ptr;

(4)int (*ptr)[3];

(5)int *(*ptr)[4];

1。 指針的類型。

語法的角度看,你只要把指針聲明語句裏的指針名字去掉,剩下的部分就是這個指針的類型。這是指針本身所具有的類型。讓我們看看例一中各個指針的類型:

(1)int *ptr; //指針的類型是 int *

(2)char *ptr; //指針的類型是char *

(3)int **ptr; //指針的類型是 int **

(4)int (*ptr)[3]; //指針的類型是 int(*)[3]

(5)int *(*ptr)[4]; //指針的類型是 int *(*)[4]

怎麼樣?找出指針的類型的方法是不是很簡單?

2。指針所指向的類型。

當你通過指針來訪問指針所指向的內存區時,指針所指向的類型決定了編譯器將把那片內存區裏的內容當做什麼來看待。從語法上看,你只須把指針聲明語句中的指針名字和名字左邊的指針聲明符*去掉,剩下的就是指針所指向的類型。例如:

(1)int *ptr; //指針所指向的類型是 int

(2)char *ptr; //指針所指向的的類型是char

(3)int **ptr; //指針所指向的的類型是 int *

(4)int (*ptr)[3]; //指針所指向的的類型是 int()[3]

(5)int *(*ptr)[4]; //指針所指向的的類型是 int *()[4]

在指針的算術運算中,指針所指向的類型有很大的作用。指針的類型(即指針本身的類型)和指針所指向的類型是兩個概念。當你對C越來越熟悉時,你會發現,把與指針攪和在一起的"類型"這個概念分成"指針的類型"和"指針所指向的類型"兩個概念,是精通指針的關鍵點之一。我看了不少書,發現有些寫得差的書中,就把指針的這兩個概念攪在一起了,所以看起書來前後矛盾,越看越糊塗。

3。 指針的值,或者叫指針所指向的內存區或地址。

指針的值是指針本身存儲的數值,這個值將被編譯器當作一個地址,而不是一個一般的數值。在32位程序裏,所有類型的指針的值都是一個32位整數,因為32位程序裏內存地址全都是32位長。指針所指向的內存區就是從指針的值所代表的那個內存地址開始,長度為si

Generated by Foxit PDF Creator ? Foxit Software

For evaluation (指針所指向的類型)的一片內存區。以後,我們説一個指針的值是XX,就相

當於説該指針指向了以XX為首地址的一片內存區域;我們説一個指針指向了某塊內存區域,就相當於説該指針的值是這塊內存區域的首地址。指針所指向的內存區和指針所指向的類型是兩個完全不同的概念。在例一中,指針所指向的類型已經有了,但由於指針還未初始化,所以它所指向的內存區是不存在的,或者説是無意義的。以後,每遇到一個指針,都應該問問:這個指針的類型是什麼?指針指向的類型是什麼?該指針指向了哪裏?

4。 指針本身所佔據的內存區。

指針本身佔了多大的內存?你只要用函數sizeof(指針的類型)測一下就知道了。在32位平台裏,指針本身佔據了 4個字節的長度。指針本身佔據的內存這個概念在判斷一個指針表達式是否是左值時很有用。

第二章。指針的算術運算

指針可以加上或減去一個整數。指針的這種運算的意義和通常的數值的加減運算的意義是不一樣的。例如:

例二:

1。 char a[20];

2。 int *ptr=a;

...

...

3。 ptr++;

在上例中,指針ptr的類型是 int*,它指向的類型是 int,它被初始化為指向整形變量a。接下來的第3句中,指針ptr被加了1,編譯器是這樣處理的:它把指針ptr的值加上了sizeof(int),在32位程序中,是被加上了4。由於地址是用字節做單位的,故 ptr 所指向的地址由原來的變量 a的地址向高地址方向增加了 4 個字節。

由於char類型的長度是一個字節,所以,原來 ptr是指向數組a的第0號單元開始的四個字節,此時指向了數組a中從第4號單元開始的四個字節。

我們可以用一個指針和一個循環來遍歷一個數組,看例子:

例三:

例三:

int array[20];

int *ptr=array;

...

//此處略去為整型數組賦值的代碼。

...

for(i=0;i<20;i++)

{

(*ptr)++;

ptr++;

Generated by Foxit PDF Creator ? Foxit Software

For evaluation only.}

這個例子將整型數組中各個單元的值加1。由於每次循環都將指針ptr加1,所以每次循環都能訪問數組的下一個單元。

再看例子:

例四:

1。 char a[20];

2。 int *ptr=a;

...

...

3。 ptr+=5;

在這個例子中,ptr被加上了5,編譯器是這樣處理的:將指針ptr的值加上5乘 sizeof(int),在 32 位程序中就是加上了 5 乘 4=20。由於地址的單位是字節,故現在的 ptr 所指向的地址比起加 5 後的 ptr 所指向的地址來説,向高地址方向移動了20個字節。在這個例子中,沒加 5前的ptr指向數組a的第0號單元開始的四個字節,加 5 後,ptr 已經指向了數組 a 的合法範圍之外了。雖然這種情況在應用上會出問題,但在語法上卻是可以的。這也體現出了指針的靈活性。

標籤:指針 語言