C/C++二維數(shù)組名和二級指針
1. 指針
1.1 一個指針包含兩方面:a) 地址值;b) 所指向的數(shù)據(jù)類型。
1.2 解引用操作符(dereference operator)會根據(jù)指針當前的地址值,以及所指向的數(shù)據(jù)類型,訪問一塊連續(xù)的內(nèi)存空間(大小由指針所指向的數(shù)據(jù)類型決定),將這塊空間的內(nèi)容轉換成相應的數(shù)據(jù)類型,并返回左值。
有時候,兩個指針的值相同,但數(shù)據(jù)類型不同,解引用取到的值也是不同的,例如,
char str[] ={0, 1, 2, 3}; /* 以字符的ASCII碼初始化 */
char * pc = &str[0]; /* pc指向str[0],即0 */
int * pi = (int *) pc; /* 指針的“值”是個地址,32位。 */
此時,pc和pi同時指向str[0],但*pc的值為0(即,ASCII碼值為0的字符);而*pi的值為50462976?;蛟S把它寫成十六進制會更容易理解:0x03020100(4個字節(jié)分別為3,2,1,0)。我想你已經(jīng)明白了,指針pi指向的類型為int,因此在解引用時,需要訪問4個字節(jié)的連續(xù)空間,并將其轉換為int返回。
2. 數(shù)組
2.1 數(shù)組名和指針
通常我們認為數(shù)組名是一個指針常量(例如,int a[10]; 那么a是一個int * const),這種理解是不全面的,正確的理解如下:
作為右值(例如,賦值語句右邊)時數(shù)組名可視為指針常量(系統(tǒng)自動轉換);作為左值,例如取地址,sizeof,則不能視為指針。
sizeof(一個數(shù)組)返回的是數(shù)組大小*每個元素占字節(jié)數(shù);而sizeof(一個指針)返回4。
2.2 二維數(shù)組
實際上,不管是一維還是多維數(shù)組,都是內(nèi)存中一塊線性連續(xù)空間,因此在內(nèi)存級別上,其實都只是一維。
(圖片在參考資料2基礎上稍作更改)
做如下定義:
int a[3][4] = {0,1,2,3,4,5,6,7,8,9,10,11};
int ** p;
p = (int**)a; /* 不做強制類型轉換會報錯 */
說明:
1)p是一個二級指針,它首先是一個指針,指向一個int*;
2)a是二維數(shù)組名,它首先是一個指針,指向一個含有4個元素的int數(shù)組;
由此可見,a和p的類型并不相同,如果想將a賦值給p,需要強制類型轉換。
3. 為什么不能將二維數(shù)組名傳遞給二級指針?
假如我們將a賦值給p,p = (int**)a; 既然p是二級指針,那么當然可以這么用:**p; 這樣會出什么問題呢?
1)首先看一下p的值,p指向a[0][0],即p的值為a[0][0]的地址;
2)再看一下*p的值,p所指向的類型是int*,占4字節(jié),根據(jù)前面所講的解引用操作符的過程:從p指向的地址開始,取連續(xù)4個字節(jié)的內(nèi)容。得到的正式a[0][0]的值,即0。
3)再看一下**p的值,誒,報錯了?當然報錯了,因為你訪問了地址為0的空間,而這個空間你是沒有權限訪問的。
實際上這是某一年華為的面試題。感興趣的還可以把a的類型定義為char類型的二維數(shù)組,看看會發(fā)生什么。
4. 二維數(shù)組和二級指針相關的參數(shù)匹配
(來源參考資料3)
5. 那么問題來了,下題答案是?
參考資料:
1. http://blog.sina.com.cn/s/blog_5c6f793801019t3t.html
2. http://c.biancheng.net/cpp/html/477.html
3. http://www.360doc.com/content/12/0421/23/8302596_205542017.
-----------------------------------------------------------------------------
以上,不知道我有沒有說清楚,有問題歡迎評論留言。
————————————————
版權聲明:本文為CSDN博主「吳一奇」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權協(xié)議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/wu_nan_nan/article/details/51741030
*博客內(nèi)容為網(wǎng)友個人發(fā)布,僅代表博主個人觀點,如有侵權請聯(lián)系工作人員刪除。