c++什么时候数组溢出_C语言,营养丰富的C语言五,变长数组不是动态数组

大家好,感谢朋友的支持阅读和关注,虽然我提出的这些小知识点看得人很少,但是每涨一个阅读和关注,都能让我开心很久,所以再次感谢一起学习的朋友们。

查余补漏:

在前几次的讲解中,有朋友提出C语言的内存分配只是malloc和free,然后还有在缓存章节的有朋友提出的内存四区,所以我在说数组之前,先进行补漏。

我们前面在说内存分配的时候,并没有明确的说明内存四区的问题,因为内存分配是从内存实际应用中提出的分配模式,而内存四区却是C语言中的内存模型,其中代码区和我上期写的缓存,在我看来,缓存是CPU中单独的一个模块,而代码区却是在编译完成后,就不变化的一块内存区域。从C语言内存四区角度来看,内存分配中的malloc和free只是内存四区中堆的操作,所以这朋友观点就有点错误。后面在缓存文章里提出内存四区,可能是这位朋友把缓存和内存混为一体了,虽然缓存我们说是内存中预留出的一块区域,但是这只是从虚拟内存角度来说,从CPU角度来说,缓存是内存与CPU之间的一个临时储存器,其读取速度要比内存快的多,所以缓存并不是内存四区的一部分。

ecf21331f41f2bedea948a1b88b51e23.png

C语言学习

数组:

数组的概念是一组数据的集合,我们称为数组。

学过解释型的脚本语言的朋友可能知道,在大多数情况下,我们在使用数组的时候,往往都会使用可变数组,因为使用起来比较方便,所以很多朋友在重新拿起C语言,使用数组的时候往往会出现越界、内存溢出等现象,其原因就是C语言的数组是静态的。

既然知道了C语言数组是静态的,为什么在网上会出现使用malloc申请动态数组的案例,这时候我们就要说说堆和栈,编译前和编译后的问题了。

一般情况下,我们在使用一个数组的时候必须指定其长度和类型,主要目的是为了让计算机明确使用了多大的内存空间。比如我们申请一个需要存放四个int类型的数组,那么就会申请一个长度为16自己的内存空间,由于这部分空间是系统自动分配的,所以它应该储存在栈区,而且长度是固定的,所以我们在存入第5个数字的时候就会出现内存溢出,因而说明C语言数组在定义之后长度不能增加,也不能减少,所以我们称之为静态数组。

在这里我就不得不说一个有趣的知识点,那就是C语言的检查系统,为了保证C语言的速度和灵活,C语言在编译期间不会对数组的越界进行检查,所以会发现,为什么编译通过了而运行时会出错,说明了点,中层干部将自己要干的活推给了下属,结果下属在工作的时候发现它干不了,于是就出现了错误。

变长数组

由于很多时候,我们经常会遇到不知道数据有多少,所以就无法明确,数组长度,那怎么办呢,于是就有了变长数组,那么这样就可以定义一个适合长度的数组了,但是有个问题是,当我们生成数组后,然后再向里面添加的时候发现,如果数组中数据已经饱和,那么新增的数据就不会出现。

#include

int main()

{

int n;

printf("Input string length: ");

scanf("%d

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值