C語言中各種類型的指針的概念總結
指針可以説是C語言本身所具有的最大特性,平時根據不同使用場合習慣地將其簡單分類,下面是小編為大家整理的C語言中各種類型的指針的概念總結,歡迎參考~
C語言中有很多關於指針的使用,指針也是C語言的靈魂所在,而且C語言中也有很多有關指針的概念,這裏學習並總結了一些知道的概念。
常量指針:首先它是一個指針,常量只是用來修飾指針的定語。其定義如下:
12 | char const * cp; char a= 'a' ; |
如何識別呢?根據右結合優先,先是*優先,所以這個cp變量是一個指針,然後是const修飾*,所以這是一個常量指針。即指向常量的指針。
12 | cp=&a; //正常語法 *cp=a; //錯誤語法,因為其指向的值是一個常量 |
指針常量:首先它是一個常量,指針是用來修飾常量的,即常量的值為一個指針地址。
12 | char * const cp; char a= 'a' ; |
如何識別呢?根據右結合優先,先是const優先,所以這個cp變量是一個常量,然後是*修飾const,所以這是一個指針常量。
12 | cp=&a; //錯誤語法,因為其地址為是一個常量 *cp=a; //正確,地址所指向的內容是一個普通字符 |
指針數組:首先它是一個數組,指針是用來修飾數組內容的,表示什麼樣的數組 :即存放指針的數組
1 | char *arr[3] = { "1" , "123" , "345" }; |
如何識別,因為[]的'優先級大於*,所以先是定義為一個數組,而後由*來修飾這個數
12 | printf ( "arr0%c" ,*arr[0]); printf ( "arr1%s" ,arr[1]); |
數組指針:首先它是一個指針,數組是修飾指針的,即指向數組的指針。
123 | char (*p)[3]; //申明時不能同時初始化 char arr[3] = { '1' , '4' , '7' }; p=&arr; //指向數組的首地址,同時指針的類型是char * [3] 類型的,即加1操作後為sizeof(char [3])三個字節數 |
如何識別:因為這次添加了一個顯示優先,所以這次先是一個指針,而後[]修飾指針
123456789 | printf ( "%c" ,(*p)[0]); //先取arr的首地址,再根據這個地址取數組內容 printf ( "%c" ,(*p)[1]); printf ( "%c" ,(*p)[2]); printf ( "%c" ,*(( char *)p+0)); //先轉換為char指針,再取值 printf ( "%c" ,*(( char *)p+1)); printf ( "%c" ,*(( char *)p+2)); printf ( "%c" ,(( char *)p)[0]); //先轉換為char指針,再取數組的值,和第一個類似 printf ( "%c" ,(( char *)p)[1]); printf ( "%c" ,(( char *)p)[2]); |
函數指針:首先它是一個指針,函數是修飾指針的,即指向函數的指針。
12345678910 | char (*func)( void ); //定義函數指針 char test( void ) { return 'A' ; } func = test; //初始化賦值 printf ( "test address: %p" ,test); printf ( "func address: %p" ,func); char ch = func(); //調用 printf ( "%c" , ch); |
如何識別,同數組指針一樣,因()的優先級,所以這個定義首先是一個指針,而後才是對指針的描述,即一個指向函數的指針,其指向的函數也是規定的:即返回的是字符類型,不需要傳入參數
指針函數:首先它是一個函數,指針修飾函數的返回類型,即一個返回指針的函數
1 | char *func( void ); |
如何識別,因為沒有擴弧,所以*的優先級沒有右邊的擴弧優先級高,所以先是規定了一個函數,*只是修飾返回值的
12345678 | char *func( void ) {
char *str = "test" ;
return str;
}
void main() {
char *test = func();
printf ( "%s" ,test); } |
結構體指針:當然其原先也是一個指針,只不過就是指向了結構體而已。故而為結構體指針。
指針結構體:指針結構體,其實也沒有必要有這個概念,無非就是帶有指針作為子項的結構體。
指針類型轉換:指針類型轉換是個有意思的東西,你可以把一個int型的指針轉換為char類型,然後再把char類型的指針轉換為int型;就像普通的字符和int型之間的轉換一樣。但指針轉換後其值沒有變,唯一變的東西就是指針的步長,即進行指針運算時的計算方式。當為char指針時其運算單位均以1個字節為1個運算單位,而當為int指針時通常都是以4個字節為1個運算單位。
指針算術:根據上面的指針類型轉換介紹可知,不同的指針類型進行算術運算時其計算方式時不相同的,其不同之處就在於其步長的字節數不同,而具體其步長為幾個字節數是以其指針類型決定的,指向char的指針步長即為1。通常的指針運算有指針與數字的加減運算,相同類型的指針的減法運算,而且還要是指向同一個數組的,不然意義不大。同理推得不同類型的指針進行運算意義更不大,甚至會報錯。
下面舉一個指針算術的例子,交換兩個變量值不利用額外變量
畢竟new關鍵字還是申請了額外的內存,雖然沒有申請變量,換湯未換藥
123456 | 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 |
只是交換變量的話也可以:
1234567 | 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整數。通過傳遞一個地址後就可以對一個共同的區域進行操作和數據共享了。
指針指針:指針的指針就是指向指針的指針,同理還有指向指針指針的指針;不過一般人的思維能做二級、三級的指針的就很好了。這裏主要是擴展一下指針與多維數組的關聯關係。從個別到一般來分解多維數組的處理。這裏個別肯定是用二維數組來舉個例子,那就可以延伸到多維數組。
-
C語言main函數的參數
導語:main函數一般都是不帶參數的,那麼什麼情況會帶參數呢?讓我們瞭解一下吧!一般main函數都是不帶參數的。因此main後的括號都是空括號。實際上,main函數可以帶參數,這個參數可以認為是main函數的形式參數。C語言規定main函數的參數只能有兩個,習慣上這兩個參數寫...
-
C++中四種加密算法之DES源代碼
DES算法是一種最通用的對稱密鑰算法,因為算法本身是公開的,所以其安全性在於密鑰的安全性。基於密鑰的算法通常有兩類:對稱算法和公開密鑰算法。對稱算法的對稱性體現在加密密鑰能夠從解密密鑰推算出來,反之亦然。下面梳理了C++中四種加密算法之DES源代碼,供大家參...
-
C/C++變量在內存中的分佈介紹
變量在內存地址的分佈為:堆-棧-代碼區-全局靜態-常量數據。同一區域的各變量按聲明的順序在內存的中依次由低到高分配空間(只有未賦值的全局變量是個例外)。本文是本站小編搜索整理的關於C/C++變量在內存中的分佈介紹,感興趣的朋友一起學習吧!!想了解更多相關信息...
-
如何使用C語言求N的階乘
使用C語言求N的階乘的方法是很多小夥伴都想知道的,下面小編給大家介紹如何使用C語言求N的階乘,歡迎閲讀!如何使用C語言求N的階乘用遞歸法求N的.階乘程序調用自身稱為遞歸(recursion).它通常把一個大型複雜的問題層層轉化為一個與原問題相似的規模較小的問題來求...