本文目錄一覽:
C語言中二維數組行指針是什麼
先從存儲的角度對二維數組作一個全面的了解。二維數組在內存中的存儲,是按照先行後列依次存放的。從內存的角度看,可以這樣說,二維數組其實就是一個一維數組,在內存中沒有二維的概念。如果把二維數組的每一行看成一個整體,即看成一個數組中的一個元素,那麼整個二維數組就是一個一維數組,它以每一行作為它的元素,這個應該很好理解。
第一,來詳細介紹二維數組與指針的關係。-
首先定義個二維數組 array[3][4],p 為指向數組的指針。
若p=array[0],此時p指向的是二維數組第一行的首地址,則 p+i 將指向array[0]數組中的元素array[0][i]。由以上所介紹的二維數組在內存中的存儲方式可知,對數組中的任一元素array[i][j] ,其指針的形式為:p+i*N+j (N為每一行的長度)。 元素相應的指針表示法為:*(p+i*N+j) ,下標表示法為:p[i*N+j] 。
For Example:
array[4][3]={{1,2,3},{4,5,6},{7,8,9},{10,11,12}};
int * p=array[0];
數組array有四個元素,分別為array[0],array[1],array[2],array[3],每個元素為包含3個元素的一維數組,
如array[0]的3個元素為 array[0][0],array[0][1],array[0][2]。
元素array[2][2]對應指針為:array+2*3+2,
指針表示法為:*(array+2*3+2) ,
下標表示法為:array[2*3+2] 。
特別注意:雖然 array[0] 與 array 都是數組首地址,但兩者指向的對象不同,這點要非常明確。array[0] 是一維數組的名字,它指向的是一維數組array[0]的首地址,所以 *array[0]與array[0][0]為同個值。而 array 是二維數組的名字,它指向的是所屬元素的首地址,其每個元素為一個行數組。它是以『行』來作為指針移動單位的,如array+i 指向的是第 i 行。對 array 進行 * 運算,得到的是一維數組 array[0] 的首地址,所以 *array 與 array[0] 為同個值。如果定義 int* p,p為指int類型的指針,指向int 類型,而不是地址。故以下操作 :p=array[0] (正確) ,p=array (錯誤) 。這點要非常注意。
第二,看看如何用數組名作地址表示其中元素。
對二維數組array ,array[0] 由 array指向,故*array 與array[0] 是相同的,依次類推可得 array[i] 由array+i 指向,*(array+i) 與array[i]是相同的。 因此,對於數組元素 array[i][j] ,用數組名表示為 *(*(array+i)+j) ,指向該元素的指針為 *(array+i)+j 。
注意:數組名雖然是地址,但與指向數組的指針性質不同。指針變數可以隨時改變其所指向對象,而數組名不可以,一旦被定義,就不能通過賦值使其指向另外一個數組,但是在Java中則可以。
第三,順便了解一下不太常用的『行數組指針』。
對於二維數組array[4][3],與int* p 。二維數組名array 不能直接賦值給p。原因前面已講過,兩隻的對象性質不同。 在C語言中,可以通過定義一個行數組指針,使得這個指針與二維數組名具有同樣的性質,實現它們之間可以直接賦值。行數組指針定義如下:
int (*p)[3]; 它表示,數組 *p 具有三個int類型元素,分別為 (*p)[0] , (*p)[1] , (*p)[2] ,即 p指向的是具有三個int類型的一維數組,也就是說,p為行指針。此時,以下運算 p=array 是正確的。
第四,二維數組作為函數參數。
二維數組作為函數參數一般有兩種方式:(1) void func(int **array){…} (2) void func(int array[ ][N])
注意第二種方式一定要指明二維數組的列數
當二維數組名作為函數實參時,對應的形參必須是一個行指針變數。
和一維數組一樣,數組名傳送給變數的是一個地址值,因此,對應的形參也必須是一個類型相同的指針變數,在函數中引用的將是主函數中的數組元素,系統只為形參開闢一個存放地址的存儲單元,而不可能在調用函數時為形參開闢一系列存放數組的存儲單元。
int main()
double a[3][4];
……
fun(a);
……
fun(double (*a)[n])
……
C語言中「二維數組行指針」是什麼意思?
數組名就是一個指針常量,它代表數組元素在內存相關信息。
1、C語言
是一門通用計算機編程語言,應用廣泛。C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。
2、C語言的發明
20世紀60年代,美國ATT公司貝爾實驗室(ATT Bell Laboratory)的研究員Ken Thompson。
3、C語言標準
2011年12月8日,國際標準化組織(ISO)和國際電工委員會(IEC)再次發布了C語言的新標準,名叫ISO/IEC 9899:2011 – Information technology — Programming languages — C [9] ,簡稱C11標準,原名C1X。這是C語言的第三個官方標準,也是C語言的最新標準。
C語言中怎樣區分一維指針和二維指針?
指針就是指針沒有維數。
指針指向的數據可以有維數,不知樓主是否問的這個意思?
比如有多維數組,就可以有多維數組的指針。
例子:
int
(*ptr)[3][3];
int
(*ptr1)[3];
則定義了兩個指針,ptr指向一個[3][3]二維int型數組,ptr1指向一個int型一維數組。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/157484.html