代码拉取完成,页面将自动刷新
同步操作将从 guohuacai/learnC2 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
void Test2dArr()
{
int arr[][2] = { {10,20}, {30,15} };
printf("arr=%d,arr+1=%d\n", arr , arr + 1); //arr=20183152,arr+1=20183160 //步长位8(2*4)跳过一行
printf("&arr=%d,&arr+1=%d\n", &arr, &arr + 1); //&arr=20183152,&arr+1=20183168//步长16,整个二维数组的长度
printf("*(arr+0)=%d,*(arr+1)=%d\n", *(arr + 0), *(arr + 1)); //*(arr+0)=20183152,*(arr+1)=20183160 //步长位8(2*4)跳过一行
printf("*arr+0=%d,*arr+1=%d\n", *arr + 0, *arr + 1); //*arr+0=20183152,*arr+1=20183156 //步长为4,跳过一列
}
注意:一、
arr:代表第0行首地址
arr+i-> &arr[i]:代表第i行首地址
*(arr+i) -> arr[i]代表第i行首元素地址
*(arr+i)+j->&arr[i][j]:代表第i行第j列元素的地址
*(*(arr+i)+j)->arr[i][j]:代表第i行第j列元素的值
二、其实真正的二维数组是不存在的,内存的空间是线性的,
所谓的二维数组只是为了更好理解而已。
实例,用一维数组的方式输出二维数组
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void printArrAs1DM(int *arr, int n)
{
for (int i = 0; i < n; i++)
{
printf("%d ", arr[i]); //结果:1 2 3 4 5 6 7 8 9 10 11 12
}
printf("\n");
}
int main(int argc, char const *argv[])
{
//Test2dArr();
int arr[][4] = {1,2,3,4,5,6,7,8,9,10,11,12};
printArrAs1DM(arr, sizeof(arr) / sizeof(arr[0][0]));
system("pause");
return 0;
}
以上代码在vs2013在编译通过,结果
1 2 3 4 5 6 7 8 9 10 11 12
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。