c prime plus 学习重点知识(数组与指针)

数组地址

我们举一个变相使用指针的例子:数组名是数组首元素的地址。也就是说,如果flizny是一个数组,下面的语句成立:
flizny = &flizny[0]; //数组名是该数组首元素的地址
flizny和&flizny[0] 都表示数组首元素的内存地址(&是地址运算符)。两者都是常量,在程序的运行过程中,不会改变。但是,可以把它们赋值给指针变量,然后可以修改指针变量的值。

地址存储

首先看下下面这段代码:
#include<stdio.h>
#define n 3
int main(void){
int p,p1;
int z[n];
for(int i=0;i<3;i++)
z[i]=i;
p=z;
p1=&z[1];
printf("%p\n",p);
printf("%p\n",p1);
return 0;
}
我们可以猜到他的输出:
c prime plus 学习重点知识(数组与指针)
这里可以看到地址相差了4,因为int类型一个占了四个字节。
但是p1-p是否等于4呢?
不是的,结果是1,为什么,我们下面讲。
c prime plus 学习重点知识(数组与指针)
另外p+1(即0019FF1C+1)是否是0019FF1D呢?
我们的系统中,地址按字节编址,short 类型占用2字节,int类型占用4字节,double 类型占用8字节。在C中,指针.加1指的是增加一-个存储单元。对数组而言,这意味着把加1后的地址是下一个元素的地址,而不是下一-个字节的地址,我们看看short为例的图(见下图)。这是为什么必须声明指针所指向对象类型的原因之一。只知道地址不够,因为计算机要知道储存对象需要多少字节(即使指针指向的是标量变量,也要知道变量的类型,否则
pti 就无法正确地取回地址上的值)。
c prime plus 学习重点知识(数组与指针)
顺带一-提,不要混淆
(dates+2)和dates+2.间接运算符()的优先级高于+,所以*dates+2
相当于(*dates) +2:
*(dates + 2) // dates 第3个元素的值
*dates + 2 // dates 第1个元素的值加2

*与++优先级

看下面语句:
total += * start++;
一元运算符 * 和++的优先级相同,但结合律是从右往左,所以start++先求值,然后才是* start.就是说,指针start先递增后指向。使用后缀形式(即start++而不是++start)意味着先把指针指向位置上的值加到total上,然后再递增指针。如果使用 * ++start,顺序则反过来,先递增指针,再使指针指向位置上的值。如果使用( * start)++,则先使用start指向的值,再递增该值,而不是递增指针这样,指针将一直指向同一个位置,但是该位置上的值发生了变化。虽然*start++ 的写法比较常用,但 * (start++)这样写更清楚。

可以这么理解,start++是 * (start++),但是start++是要在这个语句执行完才执行递增操作的,所以指针指向的值是在执行结束才改变的,total加的是start的值。
还是不理解可以看看下面这段程序截图:
c prime plus 学习重点知识(数组与指针)
更新未完