首先,强调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];