课程名称: 物联网/嵌入式工程师
课程章节: 第二周 计算机基础和C语言
主讲老师: 大白老师
课程内容:
今天主要学习了指针数组的相关内容以及它们之间的联系。
课程收获:
类比之前的int,char数组,正因为有许多相同类型的元素,所以有了数组定义,指针数组其实也一样,指针数组中的元素是用来保存地址的,定义指针数组时可以像这样:
数据类型 *变量名[元素个数];
例如: int *p[5];
每个指针的数据类型都是int *。
如果要计算元素个数其实跟前面的一维数组一样:
len = sizeof(p)/sizeof(p[0]);
接下来具体写一下:
比如说我定义三个整数,想用指针数组来输出:
int a=10,b=20,c=30;
int *p[3]={&a,&b,&c};
int len =sizeof(p)/sizeof(p[0]);
for(i=0;i<len;i++)
{
printf("%d\n",*p[i]);
}
//当然还有其他输出形式:
//printf("%d\n",*(*(p+i)));也是可以的
其实像上面的例子,我们可以不用定义len来计算长度的。
让指针数组结尾带NULL,使遍历时不依靠计算整个数组大小就可以在结尾遍历结束.
int a = 10,b = 20,c = 30;
int *p_array[] = {&a,&b,&c,NULL};
int i = 0;
for(i = 0;p_array[i] != NULL;i++)
{
printf("%p\n",p_array[i])
}
这样也是挺方便的
下面是老师上课讲的例题:
char a[] = {"zhao"};
char b[] = {"qian"};
char c[] = {"sun"};
//用指针数组来输出zhao qian sun
首先定义一个
char *q[]={a,b,c,NULL};
for(i=0;q[i]!=NULL;i++)//总体上遍历q数组
{
for(t=q[i];*t!='\0';t++)
//思路就是得到q数组的子元素地址然后进行遍历,比较关键,一定得清楚
{
printf("%c",*t);
}
printf("\n");
}
二级指针保存指针数组的地址
示例用法:
char a = 10,b = 20,c = 30;
char *array[] = {&a,&b,&c,NULL};
//char **q = &array[0];
char **q = array; //q<===>array;
//结论:针数组的首地址应该定义二级指针变量来保存
一维数组的特性:
int a[5] = {10,20,30,40,50}; //整型数组
int *p = a;
a[i]<===>*(a + i)<===>*(p + i)<==>p[i]
===================================
char a = 10,b = 20,c = 30;
char *array[] = {&a,&b,&c,NULL};
char **q = array; //q<===>array
数组的特点: 获得的是地址
array[i]<====>*(array + i)<===>*(q + i) <===>q[i]
获得数据的方法:
*array[i]<====>*(*(array + i))<===>*(*(q + i)) <===>*q[i]
作业:
答案:
#include <stdio.h>
#include <stdlib.h>
int main()
{
char a1[] = "abCde";
char a2[] = "XYZBBQ";
int i;
char *t=NULL;
char *p_array[] = {a1,a2,NULL};
for(i=0;p_array[i]!=NULL;i++)
{
for(t=p_array[i];*t!='\0';t++)
{
if((*t>='a')&&(*t<='z'))
{
*t=*t-32;
}
else if((*t>='A')&&(*t<='Z'))
{
*t+=32;
}
}
printf("%s\n",p_array[i]);
}
return 0;
}
每日一句:
当你的能力还驾驭不了你的目标时,就应该沉下心来历练