c語言中,指針加1的狀況.指針變量詳細介紹

指針是一個特殊的變量,它裏面存儲的數值被解釋成爲內存裏的一個地址。 要搞清一個指針須要搞清指針的四方面的內容:數組

  1. 指針的類型,
  2. 指針所指向的 類型,
  3. 指針的值或者叫指針所指向的內存區,
  4. 還有指針自己所佔據的內存區。

讓咱們分別說明。函數

先聲明幾個指針放着作例子: 
  例一: 
  (1)int *ptr; 
  (2)char *ptr; 
  (3)int **ptr; 
  (4)int(*ptr)[3]; 
  (5)int*(*ptr)[4]; spa

 

指針的類型 指針


  從語法的角度看,你只要把指針聲明語句裏的指針名字去掉,剩下的部分就是這個指針的類型。這是指針自己所具備的類型。讓咱們看看例一中各個指針的類型: 
  (1)int*ptr;//指針的類型是int* 
  (2)char*ptr;//指針的類型是char* 
  (3)int**ptr;//指針的類型是int** 
  (4)int(*ptr)[3];//指針的類型是int(*)[3] 
  (5)int*(*ptr)[4];//指針的類型是int*(*)[4] 
  怎麼樣?找出指針的類型的方法是否是很簡單? 內存

 

指針所指向的類型 編譯器


  當你經過指針來訪問指針所指向的內存區時,指針所指向的類型決定了編譯器把那片內存區裏的內容當作什麼來看待。 
  從語法上看,你只須把指針聲明語句中的指針名字和名字左邊的指針聲明符*去掉,剩下的就是指針所指向的類型。例如: 
  (1)int*ptr;//指針所指向的類型是int 
  (2)char*ptr;//指針所指向的的類型是char 
  (3)int**ptr;//指針所指向的的類型是int* 
  (4)int(*ptr)[3];//指針所指向的的類型是int()[3] 
  (5)int*(*ptr)[4];//指針所指向的的類型是int*()[4] 
  在指針的算術運算中,指針所指向的類型有很大的做用。 io

  指針的類型(即指針自己的類型)和指針所指向的類型是兩個概念。當你對C愈來愈熟悉時,你會發現,把與指針攪和在一塊兒的 "類型 "這個概念分紅 "指針的類型 "和 "指針所指向的類型 "兩個概念,是精通指針的關鍵點之一。我看了很多書,發現有些寫得差的書中,就把指針的這兩個概念攪在一塊兒了,因此看起書來先後矛盾,越看越糊塗。 編譯


指針的值,或者叫指針所指向的內存區或地址 變量

 

  指針的值是指針自己存儲的數值,這個值將被編譯器看成一個地址,而不是一個通常的數值。在32位程序裏,全部類型的指針的值都是一個32位整數,由於32位程序裏內存地址全都是32位長。 指針所指向的內存區就是從指針的值所表明的那個內存地址開始,長度爲sizeof(指針所指向的類型)的一片內存區。之後,咱們說一個指針的值是XX,就至關於說該指針指向了以XX爲首地址的一片內存區域;咱們說一個指針指向了某塊內存區域,就至關於說該指針的值是這塊內存區域的首地址。 循環

  指針所指向的內存區和指針所指向的類型是兩個徹底不一樣的概念。在例一中,指針所指向的類型已經有了,但因爲指針還未初始化,因此它所指向的內存區是不存在的,或者說是無心義的。

  之後,每遇到一個指針,都應該問問:這個指針的類型是什麼?指針指的類型是什麼?該指針指向了哪裏?

 

指針自己所佔據的內存區

 

  指針自己佔了多大的內存?你只要用函數sizeof(指針的類型)測一下就知道了。在32位平臺裏,指針自己佔據了4個字節的長度。 

  指針自己佔據的內存這個概念在判斷一個指針表達式是不是左值時頗有用。 


指針的算術運算 


指針能夠加上或減去一個整數。指針的這種運算的意義和一般的數值的加減運算的意義是不同的。例如: 
  例二: 
  一、char  a[20]; 
  二、int *ptr = a; 
  ... 
 ... 
  三、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++; 

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

例四:   一、char a[20];   二、int *ptr = a;   ...   ...   三、ptr += 5;   在這個例子中,ptr被加上了5,編譯器是這樣處理的:將指針ptr的值加上5乘sizeof(int),在32位程序中就是加上了5乘4=20。因爲地址的單位是字節,故如今的ptr所指向的地址比起加5後的ptr所指向的地址來講,向高地址方向移動了20個字節。在這個例子中,沒加5前的ptr指向數組a的第0號單元開始的四個字節,加5後,ptr已經指向了數組a的合法範圍以外了。雖然這種狀況在應用上會出問題,但在語法上倒是能夠的。這也體現出了指針的靈活性。

相關文章
相關標籤/搜索