c++内存分配方式

本文详细介绍了内存分配的三种方式:静态数据存储、堆栈数据存储和堆内存分配。并阐述了如何避免常见的内存错误,如内存分配未成功、未初始化就引用内存、内存越界操作和忘记释放内存等。同时强调了正确使用free和delete函数的重要性,以及如何避免“野指针”问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、内存分配的三种方式:

1、静态数据存储数据分配,内存在程序编译的时候就已经分配好了(即已经编址),这些内存在程序的整个运行期间都存在,例如:常量,全局变量,静态变量(static)。

2、在堆栈上创建的局部变量,函数内部变量(包括形参)的内存单元,函数结束时这些内存单元自动释放(堆栈清退)。堆栈内存分配运算内置于处理器的指令集中,效率很高,并且不存在失败的危险,但是分配的内存容量有限。

3、从堆(heap)上分配,亦称动态分配,程序在运行期间用malloc或new申请内存,程序员自己掌握释放内存的恰当时机(free或delete)。

注意:如果使用堆栈存储和静态存储能够满足应用要求,那么就不要使用动态存储。

二、常见的内存错误及其对策

1、内存分配未成功,却使用它。(解决方法:在使用内存前检验指针是否为NULL)

2、内存分配成功,但是未初始化就引用它。(解决方法:分配内存成功后,对其进行初始化)

3、内存分配成功且已经初始化,但操作越过了内存的边界。(解决办法:申请时注意数组下表,不要越界)

4、忘了释放内存或者只释放了部分内存,因此造成内存泄露。(解决方法:动态申请的内存释放并且必须配对,程序中malloc与free的使用次数一定要相同,否则肯定有误。(new/delete同理))

5、释放了内存却继续使用它。

三、free和delete只是把指针所指向的内存释放掉了,但并没有把指针本身干掉。(指针被释放内存后,后面不能再对该指针进行操作,否则会出错)

四、杜绝“野指针”

1、没有初始化指针变量,任何指针变量刚被创建时不会自动成为NULL指针,它默认值是随机的,它会乱指一气。故,指针变量在创建的同事应该初始化,要么将指针设置为NULL,要么让它指向有效的内存。例如:

char *p=NULL;

char *str=(char *)malloc(100);

2、指针p被free或者delete之后,没有职位NULL,让人误认为P仍然是个有效的指针。

3、指针操作超越了变量的作用范围,这种情况让人防不胜防。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值