栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C/C++数组和malloc、new使用差别

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C/C++数组和malloc、new使用差别

首先,强调malloc和new差别,malloc使用在c语言中,而在c++中多以new为主,两者对应的释放函数也存在差别free()和delete()。这里不对两者做重点分析,而对数组进行差异讲解。

问题:有了数组,为什么还需malloc和new呢?(问题的关键和核心)

答:
数组其实分为静态联编和动态联编。
所谓静态联编就是我们平时直接int arr[5];这种形式的,它会在程序编译时直接生成,开辟空间,也就导致了int length = 5; int arr[length];报错,识别length有误,因为编译阶段根本不知道length是啥,只是做好一些基础工作,在翻译阶段才会将所谓的关系进行链接,因此会length报错。
这个问题很大程度上限制了我们对于函数中动态数组的创建,比如,每次传入函数中的数组大小不同,如果我们每次都创建很大的数组,以保证数据不会溢出,这样的成本过于高,尤其是数组大小相差很大的时候,会造成内存浪费,那还有办法吗?
有!就是动态数组,如果我在程序运行过程中,再为数组开辟空间,它便可以识别传入的参数量。这也就是malloc()和new()函数的原理,利用函数在运行时创建数组,以保证对数组输入变量参数量的识别。int *p = new int[5];

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/302588.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号