目录
2.3.2. 为什么要讲步长,所以就来到了开始的问题,数组地址和其首元素地址的区别
本章节文章是作者通过观看《C语言深度剖析》等各种资料总结的精华,基础部分省略了不少,是为了让大家能够更加深入了解C语言的魅力!因为为了避免与之前的文章发生赘述,所以就直接讲作者认为的精华部分哈!现在正文开始!
谁都不能阻挡你成为更优秀的人。
2. 数组
1.1 概念:
数组是具有相同数据类型的集合。
#define N 10int a [ N ] = { 0 }; // 定义并初始化数组
2.2. 数组的内存布局
[0]先入栈[0]的地址最大?其实我们之前说过的数组在栈中的布局也是[0]最小然后递增的。
所以:
在开辟空间的角度,不应该把数组认为成一个个独立的元素,应该整体开辟空间,整体释放。
2.3 理解&a【0】和&【a】的区别
2.3.1. 我们先来看步长
对指针+1,其实是加上其指向类型的大小,默认看自身类型,有强转看强转类型。
一级指针指向的目标会有很多种(char,short等)所以+(-)1的步长也会有很多种。
但是从二级指针开始,指向的内容就是指针了,所以步长就确定了,
32位平台下是4字节,64平台下是8字节!
2.3.2. 为什么要讲步长,所以就来到了开始的问题,数组地址和其首元素地址的区别
上面的加一可以说是指向下一个元素,下面的加一可以说是指向下一个数组。
&arr[0] 和 &arr虽然地址数字一样大,但是类型意义完全不同。
因为首元素地址和数组的地址,在地址对应的字节是重叠的!所以地址数据值相等。
2.4. 数组名a做为左值和右值的区别
数组名可以做右值,代表数组首元素的地址数组名做右值,本质等价于 &arr[0]
这个有报错,q是数组指针,后面讲。
今天的内容就到这里了哈!!!
真不是作者今天偷懒了只讲这么一点哈!
只是作者觉得先把指针和数组单独讲,然后合着讲会好一点。
下一期就开始合着讲了哈!
要是认为作者有一点帮助你的话!
就来一个点赞加关注吧!!!当然订阅是更是求之不得!
最后的最后谢谢大家的观看!!!
你们的支持是作者写作的最大动力!!!
下期见哈!!!