二级指针
- 解引用消去指向能力
int a3 = 0, a2 = 0, a1 = 0, a0 = 0;
int* p3 = &a3, * p2 = &a1, * p0 = &a0;
int** s = &p0;
s+1=s+sizeof(int*)*1
*s+1=*s+sizeof(int)*1
int* p[4];//整型数组元素为指针
int(*s)[4];=&ar//存放数组地址,数组名是首元素的地址,&ar整个数组的地址,ar代表数组首元素的地址
s+1:加的是数组大小,加16字节
*s+1:加的是整型元素大小,加4字节
二维数组
- 多个相同的一维数组构成
行优先存放,对于二维数组是初始化,第一维的长度可以去缺省,第二维不可缺省
2.行索引-列索引
#include<stdio.h>
#include<ctype.h>
#include<assert.h>
#include<limits.h>
#include<string.h>
#include<stdlib.h>
int main()
{
int ar[3][4];
int row = 3, col = 4;
for (int i = 0; i < row; ++i)
{
for (int j = 0; j < col; ++j)
{
ar[i][j] = i + j;
*(*(ar + i) + j) = i + j;
}
}
for (int i = 0; i < row; ++i)
{
for (int j = 0; j < col; ++j)
{
printf("%4d", ar[i][j]);
}
printf("\n");
}
printf("\n");
return 0;
}
#include<stdio.h>
#include<ctype.h>
#include<assert.h>
#include<limits.h>
#include<string.h>
#include<stdlib.h>
int main()
{
int ar[5][2] = { 1,2,3,4,5,6,7,8,9,10 };
int(*s)[2] = &ar[1];
int* p = ar[1];
printf("%d \n", s[2][3]);//10
printf("%d \n", p[3]);//6
return 0;
}