指针进阶系列之1----指针与数组

我们要使用指针的话,首先是要弄明白指针是什么?

那么指针是什么呢?

指针就是地址

指针变量就是存放地址的地方

#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的不同了吧。

以上只是作者学习用来的总结,有什么问题,还请大家提出来,改正.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值