数组里面所有的元素是连续的内存存放的,数组名是数组第一个字节的内存地址,并且数组名a也表示指针,在表达式可以被转换为和 p 等价的指针!a作为右值 并不表示a地址存储的内容, 而是数组首元素首地址
指针进行加法(减法)运算时,它前进(后退)的步长与它指向的数据类型有关。p指向的数据类型是int ,在内存中占4个字节(Byte) ,p+1表示前进4个字节。
用指针访问二维数组先看看常见指针变量的定义:
int a[2][3] = { { 2,3,6 },{ 4,5,8 }};int(*p)[3] = a;//数组指针,指向一维数组的指针,printf("a=%p &a[0]=%pn", a, &a[0]);//400printf("*a=%p a[0]=%p &a[0][0]=%pn", *a, a[0],&a[0][0]);//400 一维数组首元素的首地址//使用整个数组的数据没有实际的含义,编译器遇到这种情况都会转换为指向该一维数组第 0 个元素的指针printf("(a+1)=%p &a[1]=%pn", a + 1, &a[1]);//412printf("*(a+1)=%p a[1]=%p &a[1][0]=%pn",*(a + 1), a[1], &a[1][0]);// printf("*(a+1)+2=%p a[1]+2 = %p &a[1][2]=%pn",*(a + 1) + 2,a[1] + 2,&a[1][2]);//420printf("*(*a+1)=%d *(a[0]+1)=%d a[0][1]=%d", *(*a + 1), *(a[0] + 1),a[0][1]);//3
指针进行加法(减法)运算时,它前进(后退)的步长与它指向的数据类型有关
p的数据类型为int (*) [3],一维数组a[0]有3个整型数据就是12个字节,a+1 = 412
a[0]的数据类型为int *
一个小练习:打印出字符串指针数组中每一个字符指针法:字符串相当于一个一位数组
#include<stdio.h>int main(){char * array[5] = { "array","11","kankanshisha","pointer","c program" }; char * (*p) = array;//指向数组元素(char指针类型)的首地址的指针 for (int i = 0; i < 5; i++){for (int j = 0; \\\'\\\' != *(*(p + i) + j); j++) {printf("%c", *(*(p + i) + j));}printf("n");}return 0;}
数组下标法:
#include<stdio.h>int main(){char * array[5] = { "array","11","kankanshisha","pointer","c program" };char * (*p)[5] = &array;//指向数组首地址的指针 (*p)===数组名字arrayfor (int i = 0; i < 5; i++){for (int j = 0; (*p)[i][j]!=\\\'\\\'; j++){printf("%c", (*p)[i][j]);}printf("n");}return 0;}