OneNote防丢
多维数组
- 一、二维数组的初始化
-
- [1.1 二维数组初始化](#1.1 二维数组初始化)
- [1.2 给定部分值](#1.2 给定部分值)
- [1.3 二维数组省略第二层的{}](#1.3 二维数组省略第二层的{})
- [1.4 省略长度](#1.4 省略长度)
- [1.5 多维数组寻址](#1.5 多维数组寻址)
- [1.6 作业](#1.6 作业)
一、二维数组的初始化
1.1 二维数组初始化
- 代码1
int arr[3][4] = {
{1,2,3,4},
{5,6,7,8},
{9,7,6,5}
};
- 代码2
int arr[3*4] = {1,2,3,4,5,6,7,8,9,10,11,12};
- 反汇编:
-
arr[3][4]的反汇编
-
arr[3*4]的反汇编
-
总结:一维数组和二维数组在底层是一致的,按照顺序将数据从低地址向高地址mov,没有大的区别。
1.2 给定部分值
-
范围内缺少值
-
超出范围
不允许,超出范围,编译不通过。
1.3 二维数组省略第二层的{}
- int arr[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12};
- int arr[3][4] = {1,2,3,4,5,6,7,8,9,10};
1.4 省略长度
- int arr[][4] = {1,2,3,4,5,6,7,8,9,10,11,12}; 编译可通过
1.5 多维数组寻址
公式:
arr[m][n][x][y][z]
找arr[a][b][c][d][e]的值
汇编寻址为arr[an xy z + bx yz + c yz + dz + e](注意,转成一维数组也是从0开始编号的),在汇编地址中寻找时,结合ebp地址和数据实际存储宽度找到内存地址。
1.6 作业
有点简单...略。
海哥牛逼。