目录
本篇介绍:
- 指针运算
- 指针和数组
- 二级指针
- 指针数组
四、指针运算
4.1 指针 + - 整数
#define N_VALUES 5
int main()
{
float values[N_VALUES];
float* pv;
//指针 + - 整数,指针的关系运算
for (pv = &values[0]; pv < &values[N_VALUES];)
{
*pv++ = 0;
}
pv = &values[0];
//打印数组
for (int i = 0; i < N_VALUES; i++)
{
printf("%d ", *(pv + i));
}
return 0;
}
4.2 指针-指针
//指针-指针
int my_strlen(char* p)
{
char* s = p;
while (*s != '\0')
{
s++;
}
return s - p;
}
int main()
{
int ret = my_strlen("abcdef");
printf("%d ", ret);
return 0;
}
前提:两个指针指向同一块空间,类型是一致的,指针-指针得到的是指针和指针之间的元素个数。
4.3 指针的关系运算
//指针的关系运算
#define N_VALUES 5
int main()
{
float values[N_VALUES];
float* pv;
for (pv = &values[N_VALUES]; pv > &values[0];)
{
*--pv = 0;
}
//代码简化,将代码修改如下:
for (pv = &values[N_VALUES - 1]; pv >= &values[0]; pv--)
{
*pv = 0;
}
//打印数组
for (int i = 0; i < N_VALUES; i++)
{
printf("%d ", *(pv + i));
}
return 0;
}
简化后的代码在大部分的编译器上是可以顺利完成任务的,然而我们还是应该避免这样写,因为标准并不保证它可行。
标准规定:
允许指向数组元素的指针与指向数组最后一个元素后面的那个内存位置的指针比较,但是不允许与指向第一个元素之前的那个内存位置的指针进行比较。
五、指针和数组
既然可以把数组名当成地址存放到一个指针中,我们使用指针来访问一个数组就成为可能
六、二级指针
指针变量也是变量,是变量就是地址,那指针变量的地址存放在哪里?
a的地址存放在pa中,pa的地址存放在ppa中。pa是一级指针,而ppa是二级指针。
打印一个数组的四种方式:
arr[i] = *(arr+i) = *(i+arr) = i[arr]
二维数组访问元素:
arr[i][j] = *(arr[i] + j) = *(*(arr+i)+j)
七、指针数组
指针数组——就是用来存放指针的数组。