簡略總結C說話中各類類型的指針的概念。本站提示廣大學習愛好者:(簡略總結C說話中各類類型的指針的概念)文章只能為提供參考,不一定能成為您想要的結果。以下是簡略總結C說話中各類類型的指針的概念正文
C說話中有許多關於指針的應用,指針也是C說話的魂魄地點,並且C說話中也有許多有關指針的概念,這裡進修並總結了一些曉得的概念。
常量指針:
起首它是一個指針,常量只是用來潤飾指針的定語。其界說以下:
char const * cp; char a='a';
若何辨認呢?依據右聯合優先,先是*優先,所以這個cp變量是一個指針,然後是const潤飾*,所以這是一個常量指針。即指向常量的指針。
cp=&a; //正常語法 *cp=a; //毛病語法,由於其指向的值是一個常量
指針常量:
起首它是一個常量,指針是用來潤飾常量的,即常量的值為一個指針地址。
char * const cp; char a='a';
若何辨認呢?依據右聯合優先,先是const優先,所以這個cp變量是一個常量,然後是*潤飾const,所以這是一個指針常量。
cp=&a; //毛病語法,由於其地址為是一個常量 *cp=a; //准確,地址所指向的內容是一個通俗字符
指針數組:
起首它是一個數組,指針是用來潤飾數組內容的,表現甚麼樣的數組 :即寄存指針的數組
char *arr[3] = {"1","123","345"};
若何辨認,由於[]的優先級年夜於*,所以先是界說為一個數組,爾後由*來潤飾這個數
printf("arr0%c\n",*arr[0]); printf("arr1%s\n",arr[1]);
數組指針:
起首它是一個指針,數組是潤飾指針的,即指向數組的指針。
char (*p)[3]; //聲名時不克不及同時初始化 char arr[3] = {'1','4','7'}; p=&arr; //指向數組的首地址,同時指針的類型是char * [3] 類型的,即加1操作後為sizeof(char [3])三個字節數
若何辨認:由於此次添加了一個顯示優先,所以此次先是一個指針,爾後[]潤飾指針
printf("%c\n",(*p)[0]); //先取arr的首地址,再依據這個地址取數組內容 printf("%c\n",(*p)[1]); printf("%c\n",(*p)[2]); printf("%c\n",*((char*)p+0)); //先轉換為char指針,再取值 printf("%c\n",*((char*)p+1)); printf("%c\n",*((char*)p+2)); printf("%c\n",((char*)p)[0]); //先轉換為char指針,再取數組的值,和第一個相似 printf("%c\n",((char*)p)[1]); printf("%c\n",((char*)p)[2]);
函數指針:
起首它是一個指針,函數是潤飾指針的,即指向函數的指針。
char (*func)(void); //界說函數指針 char test(void) { return 'A'; } func = test; //初始化賦值 printf("test address: %p\n",test); printf("func address: %p\n",func); char ch = func(); //挪用 printf("%c\n", ch);
若何辨認,同數組指針一樣,因()的優先級,所以這個界說起首是一個指針,爾後才是對指針的描寫,即一個指向函數的指針,其指向的函數也是劃定的:即前往的是字符類型,不須要傳入參數
指針函數:
起首它是一個函數,指針潤飾函數的前往類型,即一個前往指針的函數
char *func(void);
若何辨認,由於沒有擴弧,所以*的優先級沒有左邊的擴弧優先級高,所以先是劃定了一個函數,*只是潤飾前往值的
char *func(void) { char *str = "test"; return str; } void main() { char *test = func(); printf("%s\n",test); }
構造體指針:
固然其本來也是一個指針,只不外就是指向了卻構體罷了。故而為構造體指針。
指針構造體:
指針構造體,其實也沒有需要有這個概念,不過就是帶有指針作為子項的構造體。
指針類型轉換:
指針類型轉換是個成心思的器械,你可以把一個int型的指針轉換為char類型,然後再把char類型的指針轉換為int型;就像通俗的字符和int型之間的轉換一樣。但指針轉換後其值沒有變,獨一變的器械就是指針的步長,即停止指針運算時的盤算方法。當為char指針時其運算單元均以1個字節為1個運算單元,而當為int指針時平日都是以4個字節為1個運算單元。
指針算術:
依據下面的指針類型轉換引見可知,分歧的指針類型停止算術運算時其盤算方法時不雷同的,其分歧的地方就在於其步長的字節數分歧,而詳細其步長為幾個字節數是以其指針類型決議的,指向char的指針步長即為1。平日的指針運算有指針與數字的加減運算,雷同類型的指針的減法運算,並且還如果指向統一個數組的,否則意義不年夜。同理推得分歧類型的指針停止運算意義更不年夜,乃至會報錯。
上面舉一個指針算術的例子,交流兩個變量值晦氣用額定變量
究竟new症結字照樣請求了額定的內存,固然沒有請求變量,換湯未換藥
int *a,*b; a=new int(10); //給指針賦值 b=new int(20); //a=0x00030828,b=0x00030840 a=(int*)(b-a); //a=0x00000006 b=(int*)(b-int(a)); //b=0x00030828 a=(int*)(b+int(a)); //a=0x00030840
只是交流變量的話也能夠:
int a = 4; int b = 5; *(((char*)&a)+1) = *((char*)&b); *((char*)&b)=*((char*)&a); *((char*)&a)=*(((char*)&a)+1); *(((char*)&a)+1)=0;
指針參數:
指針參數就是指,指針作為函數的參數停止傳遞,由於C說話只支撐單向傳值,且前往值只能是一個值類型,所以想要從函數內前往多個內容或許與函數體有一個配合的數據操作區域,那這個時刻便可以斟酌經由過程傳指針參數的方法了。傳指針也是傳值,只不外這時候的值為指針指向的地址,也就是一個int整數。經由過程傳遞一個地址後便可以對一個配合的區域停止操作和數據同享了。
指針指針:
指針的指針就是指向指針的指針,同理還有指向指針指針的指針;不外普通人的思想能做二級、三級的指針的就很好了。這裡重要是擴大一下指針與多維數組的聯系關系關系。從個體到普通來分化多維數組的處置。這裡個體確定是用二維數組來舉個例子,那便可以延長到多維數組。