我们要使用指针的话,首先是要弄明白指针是什么?
那么指针是什么呢?
指针就是地址
指针变量就是存放地址的地方
#include<stdio.h>
int main()
{
int arr[10]={0};
int *p=arr;
return 0;
}
接下来我们看这段代码
先是定义了一个整型数组,名字是arr,元素个数是10个,初始化为0.
首先,一定要弄明白(类型)这个概念,我们知道,这个数组是整型,但是为什么是整型呢?
那是因为数组中可以存放元素的类型是int型的,也可以这么说,它指向的元素类型就是int型的。
那我们知道,数组在内存中是一段连续开辟的空间(记住是连续的,后面会有用的)
1.arr;
2.=arr;
3.p=arr;
4.*p=arr;
5.int* p=arr;
看上面这段定义的流程:
1.内存空间就会有一段地址,数组名就是数组首元素的地址
2.赋值给变量
3.拿到地址我就要想到用指针变量(p)去存放它,所以要定义一个指针变量.
4.加上*代表一个指针
5.因为这个指针指向的数组类型是int,所以我们也要用int型才能指向它,所以加上int类型,
就变成了整型指针。(类型一定要清楚)
但是这里指针变量存放并不是整个数组的地址,而是数组首元素的地址,它指向的是数组的首元素(所以才用到整型指针 ---> 整型元素)
但是如果是直接
int* p=&arr;
和上面的arr是有差别的,这段代码是错误的!(会报上方错误)也就是类型不匹配。
我们现在拿到的是整个数组的地址,那么我们的指针类型就不应该是整型的指针了,而是指向数组的指针了(数组指针,这个后面我们再讨论)
我们再拿代码来说明数组名arr和&arr的不同之处
看到这里你是不是有疑问了?
这也没有什么不一样的,同样的地址,接着往下看。
这里我多加了一行代码就是&arr[0],这里就是为了证明数组名是首元素的地址最好的证据。
我们接下来分析一下运行结果:
你会发现前三个输出全是一样的,你会怀疑这个作者是不是放屁,说了一顿废话
别着急,我们接下来看后三行的结果
你会发现数组名的地址和首元素的地址是从
006FFCDC ---> 006FFCE0
通过计算你就会发现刚刚好是一个整型指针的字节大小:4个字节(32位系统)
但是&arr就不同了
006FFCDC ---> 006FFD04
你会发现这刚好是一个数组的字节大小,那么你是不是明白了&arr和arr的不同了吧。
以上只是作者学习用来的总结,有什么问题,还请大家提出来,改正.