二維數(shù)組的地址分布究竟是什么樣的?
在數(shù)組專題的文章講解中,講到了二維數(shù)組的地址分布情況,之后也陸續(xù)有錄友與我交流這個問題,這幾天抽空去做一下實驗,發(fā)現(xiàn)在C++中二維數(shù)組的地址空間是連續(xù)的。
所以單獨發(fā)文來講一講這個問題。
C++測試代碼如下:
- // 測存儲地址
- void test_arr() {
- int array[2][3] = {
- {0, 1, 2},
- {3, 4, 5}
- };
- cout << &array[0][0] << " " << &array[0][1] << " " << &array[0][2] << endl;
- cout << &array[1][0] << " " << &array[1][1] << " " << &array[1][2] << endl;
- }
- int main() {
- test_arr();
- }
測試地址為
- 0x7ffee4065820 0x7ffee4065824 0x7ffee4065828
- 0x7ffee406582c 0x7ffee4065830 0x7ffee4065834
注意地址為16進制,可以看出二維數(shù)組地址是連續(xù)一條線的。
一些錄友可能看不懂內(nèi)存地址,我就簡單介紹一下, 0x7ffee4065820 與 0x7ffee4065824 差了一個4,就是4個字節(jié),因為這是一個int型的數(shù)組,所以兩個相信數(shù)組元素地址差4個字節(jié)。
0x7ffee4065828 與 0x7ffee406582c 也是差了4個字節(jié),在16進制里8 + 4 = c,c就是12。
如圖:
可以看出在C++中二維數(shù)組在地址空間上是連續(xù)的。
像Java,Python是沒有指針的,同時也不對程序員暴漏其元素的地址,尋址操作完全交給虛擬機。
所以看不到每個元素的地址情況,這里我以Java為例,也做一個實驗。
- public static void test_arr() {
- int[][] arr = {{1, 2, 3}, {3, 4, 5}, {6, 7, 8}, {9,9,9}};
- System.out.println(arr[0]);
- System.out.println(arr[1]);
- System.out.println(arr[2]);
- System.out.println(arr[3]);
- }
輸出的地址為:
- [I@7852e922
- [I@4e25154f
- [I@70dea4e
- [I@5c647e05
這里的數(shù)值也是16進制,這不是真正的地址,而是經(jīng)過處理過后的數(shù)值了,我們也可以看出,二維數(shù)組的每一行頭結點的地址是沒有規(guī)則的,更談不上連續(xù)。
所以Java的二維數(shù)組可能是如下排列的方式:
總結
不同編程語言的數(shù)據(jù)結構在地址中的分布方式是不一樣的,C++中我們是可以直接獲取元素的地址,通過實驗,我們也證實了二維數(shù)組的元素確實是相鄰的。
在其他語言中,并沒有指針,也獲取不到每個元素的地址,以Java為例,通過實驗可以推測可能Java里的二維數(shù)組是不相鄰的。
這里算是對之前講解數(shù)組內(nèi)容的一個糾正,也是給大家做一個科普。
大家可以發(fā)現(xiàn)C++賦給程序員足夠的自由,這也是C++的魅力所在。
但有的時候太自由了往往不是好事,編程語言都是各有各的優(yōu)點,也不是哪門語言難,它就一定好!
好了,希望通過本篇大家可以二維數(shù)組的內(nèi)存分布有個初步的認識了。
本文轉(zhuǎn)載自微信公眾號「代碼隨想錄」,可以通過以下二維碼關注。轉(zhuǎn)載本文請聯(lián)系代碼隨想錄公眾號。