我們知道當定義乙個變數後,系統會為這個變數分配記憶體空間,那麼變數名就是這個空間的名字,這個空間可以儲存值,這個空間有位址。
如:int num = 5;
這是乙個整型變數,系統為這個變數分配了記憶體空間,num就是就是這個記憶體空間的名字,5就是儲存在這個空間裡的值,這個空間有位址。
num++:就是num對應的空間裡的值加1,即5+1。
int *p = #
這是定義了乙個指標變數,並初始化了,系統為這個指標變數分配了記憶體空間,p就是這個記憶體空間的名字,num的位址就是儲存在這個空間裡的值,這個空間本身也有位址。
(*p)++: 就是p指向的記憶體空間裡的值加1,即num的值。
int ** pp =&p;
這是定義了乙個二維指標變數,系統為這個變數分配了記憶體空間,pp就是這個記憶體空間的名字,指標p的位址就是儲存在這個空間裡的值,這個空間本身也有位址。
(**pp)++: 就是pp指向的指標指向的記憶體空間的值加1,即num的值。
注:指標加1是加乙個步長,不同的指標有不同的步長,由指標的型別決定。
像三維指標甚至更高維度的指標都是這樣一層一層巢狀的。
對於陣列我們需要弄清楚對陣列名取位址與對陣列位址取值之間關係。
首先對於一維陣列,一維陣列名是乙個指標常量,它儲存的是陣列首元素的位址。
對一維陣列名取位址等於一維陣列的位址。
對一維陣列的位址取值等於一維陣列首元素的位址。
二維陣列:
二維陣列名是乙個指標常量,它儲存的是首個一維陣列的位址。
對二維陣列名取位址等於二維陣列的位址。
對二維陣列的位址取值等於二維陣列中首個一維陣列的位址。
例:*(*(a+i)+j)
*(*(a+i)+j): 第i+1個一維陣列的第j+1個元素的值。
指標與陣列,指標陣列 陣列指標
int a 10 print n a p,a p a,a print n a 1 p,a 1 p a 1,a 1 a做乙個指標,步長為4,指向乙個元素,a做乙個指標,步長為40,指向乙個維陣列 int b 3 4 print n b p,b p,b p b,b,b print n b 1 p,b 1...
指標陣列與陣列指標
1.指標陣列 指標陣列中每乙個元素都是乙個指標,也既是存放字串的首位址。所以指標陣列適合處理若干個長度不等的字串。定義的一般形式為 型別說明符 指標陣列名 陣列長度 例如 int p 3 宣告乙個陣列,指標陣列p,由3個int型別指標變數元素組成 從運算子的優先順序分析,由於 的優先順序大於 所以p...
指標陣列與陣列指標
呵呵,實在是厭倦了繞口的解釋。指標陣列,故名思義,就是指標的陣列,陣列的元素是指標 陣列指標,同樣,就是直想陣列的指標。簡單舉例說明 int p 2 首先宣告了乙個陣列,陣列的元素是int型的指標。int p 2 宣告了乙個指標,指向了乙個有兩個int元素的陣列。其實這兩種寫法主要是因為運算子的優先...