C语言二维数组的内存结构图与Java二维数组的内存结构图
来源:互联网 发布:举报网络诈骗怎么写 编辑:程序博客网 时间:2024/04/30 05:20
Java二维数组的内存结构图:
今天看了个视频,说Java中二维数组是这样的:java中的二位数组是按维存储的。
在Java中是可以这样的,二维数组有三种定义格式!
定义格式1:
定义格式1的内存图:
定义格式2:
定义格式2的内存结构图:
定义格式3:
定义格式3内存图:
C语言二维数组的内存结构图:
突然,感觉和自己脑海中C的不一样。还专门去看了下C的。
void main(){int a[3][2];cout << a <<"\t"<< &a << endl<<endl;cout << a[0] << "\t" << a[1] << "\t" << a[2] << endl << endl;cout << &a[0][0] << "\t" << &a[0][1] << endl << endl;cout << &a[1][0] << "\t" << &a[1][1] << endl << endl;cout << &a[2][0] << "\t" << &a[2][1] << endl << endl;}
运行结果:
也就是说,C语言的二维数组确实是下面这样:
,C语言的二维数组是连续一维存储的。
,C语言的二维数组是连续一维存储的。
再详细看一下:
#include<iostream>using namespace std;void main(){int a[3][3] = { 1, 5, 9, 15, 28, 44, 65, 88, 99 };cout << "各元素:" << endl;cout << a[0][0] << " " << a[0][1] << " " << a[0][2] << " " << endl;cout << a[1][0] << " " << a[1][1] << " " << a[1][2] << " " << endl;cout << a[2][0] << " " << a[2][1] << " " << a[2][2] << " " << endl;cout << "\n各元素地址:" << endl;cout << &a[0][0] << " " << &a[0][1] << " " << &a[0][2] << " " << endl;cout << &a[1][0] << " " << &a[1][1] << " " << &a[1][2] << " " << endl;cout << &a[2][0] << " " << &a[2][1] << " " << &a[2][2] << " " << endl;cout << "\na[0]:" << a[0] << " &a[0][0]: " << &a[0][0] << endl; //a[0] <==> &a[0][0]cout << "a[1]:" << a[1] << " &a[1][0]: " << &a[1][0] << endl; //a[1] <==> &a[1][0]cout << "a[2]:" << a[2] << " &a[2][0]: " << &a[2][0] << endl; //a[2] <==> &a[2][0]cout << "\na[0]+1:" << a[0]+1 << " &a[0][1]:" << &a[0][1] << endl; //a[0]+1 <==> &a[0][1]cout << "a[1]+1:" << a[1]+1 << " &a[1][1]:" << &a[1][1] << endl; //a[1]+1 <==> &a[1][1]cout << "a[2]+1:" << a[2]+1 << " &a[2][1]:" << &a[2][1] << endl; //a[2]+1 <==> &a[2][1]cout << "\n&a:" << &a << endl; //&a:数组的首地址cout << "&a +1:" << &a + 1 << endl; //注意步长:直接跳了一个二维数组cout << "\na+0:" << a << endl; //第0行的首地址cout << "a+1:" << a + 1 << endl; //第1行的首地址cout << "a+2:" << a + 2 << endl; //第2行的首地址cout << endl;cout << "(*a)[2]:" << (*a)[2] << endl;cout << "(*a +1)[2]:" << (*a + 1)[2] << endl;cout << "*a[2]:" << *a[2] << endl;cout << endl;cout << "*a:" << *a << endl;cout << "*(a+1):" << *(a + 1) << endl;cout << "*(a + 1) + 2:" << *(a + 1) + 2 << endl;cout << "*(*(a+1)+2):" << *(*(a + 1) + 2) << endl;}
附录:
java二维数组的遍历:
public class Main {public static void main(String[] args) {int[][] arr = { { 1, 2, 3 }, { 4, 5 }, { 6 } };for (int row = 0; row < arr.length; row++) { // 外层循环:二维数组的长度,也就是一维数组的个数for (int col = 0; col < arr[row].length; col++) { // 内层循环:某一维数组的长度System.out.print(arr[row][col] + " ");}System.out.println();}}}打印结果:
1 2 3
4 5
6
0 0
- C语言二维数组的内存结构图与Java二维数组的内存结构图
- C/C++与Java二维数组的内存分配区别
- 讯飞实训之二维数组结构图
- 静态二维数组与动态二维数组的内存布局
- C语言为二维数组动态分配内存的问题
- 二维数组内存的初始化
- 二维数组的内存申请
- 二维数组的内存分配
- C语言中二维数组动态分配内存
- C语言二维数组动态内存分配
- C语言-----二维字符串数组内存图解
- C语言的二维数组
- java 二维数组内存分析
- C语言实现一、二维数组动态内存分配与释放以及图像的线性插值放大与优化
- C/C++动态二维数组的内存分配和释放 .
- C/C++动态二维数组的内存分配和释放
- C语言中使用内存较大的二维数组出错的解决办法
- 二维数组的内存分配及删除
- LeetCode54——Spiral Matrix
- 程序员需要具备的基本技能
- python下的可变对象与不可变对象
- C++输入流cin方法详解
- Login
- C语言二维数组的内存结构图与Java二维数组的内存结构图
- Linux下安装docker
- Android 设置Settings源码导入eclipse
- 修改Ubuntu默认运行级别,启动字符界面
- Alpha测试与Beta测试及区别
- python学习笔记(一)变量和数据类型
- UVA - 129 Krypton Factor
- 理解B+树算法和Innodb索引
- Shell 简洁教程