首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么指针的分配内存在函数之后仍然存在,而不是数组?

指针的分配内存在函数之后仍然存在,而不是数组的原因是因为指针和数组在内存中的存储方式不同。

指针是一个变量,它存储了一个内存地址,指向实际数据所在的位置。当我们在函数中分配内存给指针时,实际上是在堆内存中为指针指向的数据分配了一块内存空间。这块内存空间在函数执行完毕后并不会被释放,因为它是在堆上分配的,需要手动释放。所以即使函数执行完毕,指针仍然可以访问到这块内存空间。

而数组是一种连续存储的数据结构,它在栈上分配内存。当我们在函数中声明一个数组时,它会在函数执行完毕后自动被释放,因为数组是在栈上分配的,函数执行完毕后栈帧会被销毁,数组所占用的内存也会被回收。

因此,指针的分配内存在函数之后仍然存在,而不是数组。这也是使用指针进行动态内存分配的一个优势,可以在函数之后继续使用指针指向的内存空间,而数组则不具备这个特性。

腾讯云相关产品和产品介绍链接地址:

  • 云服务器(CVM):提供可扩展的计算容量,满足各种业务需求。产品介绍
  • 云数据库 MySQL 版(CDB):提供高性能、高可靠的云数据库服务。产品介绍
  • 云存储(COS):提供安全、稳定、低成本的云端存储服务。产品介绍
  • 人工智能平台(AI Lab):提供丰富的人工智能算法和模型,帮助开发者快速构建智能应用。产品介绍
  • 物联网通信(IoT Hub):提供稳定、安全、高效的物联网设备连接和数据通信服务。产品介绍
  • 视频直播(CSS):提供高清、低延迟的在线视频直播服务。产品介绍
  • 区块链服务(TBC):提供安全、高效的区块链应用开发和部署服务。产品介绍
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

数组大小分配(动态内存分配)

在很多情况下,我们无法确定要使用多大的数组。一般申请大于估计数目的固定大小,这样程序在运行时就申请了固定的大小,你觉得数组定义足够大,但是如果某种原因,数组的个数增大或减小,你又必须重新修改程序,扩大数组的存储范围。这种分配固定大小内存分配的方法称为静态内存分配。但是这种分配方法存在比较严重的缺陷,特别是处理某些问题时,在大多数情况下会浪费大量的内存空间;在少数情况下,当申请的数组不够大时,可能引起下标越界错误,甚至导致严重的后果。 为了解决这个问题,提出了动态内存分配。所谓动态内存分配是指在程序执行的过程中动态地分配或者回收存储空间的内存分配方法。动态分配不像数组等静态内存分配方法需要预先申请内存空间,而是由系统根据程序的需要即时分配,且分配的大小就是程序要求的大小。从以上动、静态内存分配比较可以知道动态内存分配相对于静态内存分配的特点:

02

面试总结-C++

堆、栈、自由存储区、全局/静态存储区、常量存储区 自由存储区存储malloc申请的内存 (1)从静态存储区域分配 。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。例如 全局变量, static 变量 。 (2)在栈上创建 。在执行函数时, 函数内局部变量的存储单元都可以在栈上创建 ,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集。 (3)从堆上分配 , 亦称动态内存分配 。程序在运行的时候用 malloc 或 new 申请任意多少的内存,程序员自己负责在何时用 free 或 delete 释放内存。动态内存的生存期由程序员决定,使用非常灵活,但问题也最多。

01

C++经典面试题(最全,面中率最高)

delete会调用对象的析构函数,和new对应free只会释放内存,new调用构造函数。malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。对于非内部数据类型的对象而言,光用maloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free。因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以及一个能完成清理与释放内存工作的运算符delete。注意new/delete不是库函数。

03
领券