立即学习:https://edu.csdn.net/course/play/10534/378150?utm_source=blogtoedu
学习目标
定义指针数组。
指针数组的初始化。
指针数组的使用。
定义数组指针。
数组指针的初始化。
数组指针的使用。
指针数组
[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。
// 定义并初始化
int *p[n] = {NULL};
// 赋值
int a[2] = {0};
int b[2] = {0};
int *p[2] = {&a, &b};
// 访问
// a[0]
int a0 = p[0][0];
int a1 = p[0][1];
int b0 = p[1][0];
int b1 = p[1][1];
// 算数运算
p = p + 1; // 会发生什么事情 ?语法错误
p++; // 会发生什么事情 ?语法错误
编程实例:使用指针数组来统计学习成绩,每个学生有3科成绩:语文、数学、英语。计算平均值,输出。使用结构体。
// 看视频
#include <stdio.h>
typedef struct {
unsigned chinese;
unsigned math;
unsigned english;
} Student;
int main(int argc, char* argv[]) {
Student *stud_p[2] = {NULL};
Student stud1 = {80, 90, 59};
Student stud2 = {70, 80, 49};
int avg = 0;
int i = 0;
stud_p[0] = &stud1;
stud_p[1] = &stud2;
for (i = 0; i < 2; i++) {
avg = (stud_p[i]->chinese + stud_p[i]->math + stud_p[i]->english) / 3;
printf("%d. %d %d %d %d\n", i + 1, stud_p[i]->chinese, stud_p[i]->math, stud_p[i]->english, avg);
}
return 0;
}
数组指针
()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
// 该语句是定义一个数组指针,指向含n个元素的一维数组。
int (*p)[n] = NULL;
// 该语句是定义一个数组指针,指向含n,m个元素的二维数组。
int (*p)[n][m] = NULL;
int (*p)[...][n][m] = NULL;
// 如何指向一维数组
int a[2] = {0};
int (*pa)[2] = &a; // 取一维数组的地址
pa++; // 指针指向哪里?
pa = a; // 这样行吗?不行的,需要指向一个数组地址,不是一个int地址
// 如何指向二维数组
int b[3][2] = {0};
int (*pb)[2] = NULL; // 该语句是定义一个数组指针,指向含4个元素的一维数组。
pb = b; // 将该二维数组的首地址赋给p,也就是b[0]或&b[0][0]
pb++; // 该语句执行过后,也就是p=p+1;p跨过行b[0][]指向了行b[1][]
// 如何指向多维数组
int x[3][2][2] = {0};
int (*px)[2][2] = x; // 不确定,试一试
// 数组的长度不一样可以吗?
// 编译器允许,但是容易出bug,最好别这么干。
int d[2] = {0};
int (*pd)[4] = &d;
编程实例:我们来验证上面的说法:
#include <stdio.h>
// 数组指针指向一维数组
void fun1() {
int a[2] = {1, 2};
int (*pa)[2] = &a;
printf("%d\n", (*pa)[0]);
}
// 数组指针指向二维数组
void fun2() {
int b[3][2] = {{1, 2}, {3, 4}, {5, 6}};
int (*pb)[2] = NULL;
int i = 0;
// 步长: sizeof(int) * 2 = 8
// pb++, offset: 8 byte
pb = b; // b是二维,当把它当成指针使用的时候,他退化成一维类型的指针. int * []
for (i = 0; i < 3; i++) {
printf("%d %d\n", (*pb)[0], (*pb)[1]);
pb++; // offset : 8 byte
}
}
void funm() {
int x[3][2][2] = {0};
int (*px)[2][2] = x;
}
int main(int argc, char* argv[]) {
fun1();
fun2();
funm();
return 0;
}
优先级
优先级:()>[]>*