c++中类实例的内存分配在什么上?
遇到一个选择题:其中的一个选项是“类实例的内存分配在heap上”,不知道对不对?要是不对为啥?谢谢了...
遇到一个选择题:其中的一个选项是 “类实例的内存分配在heap上”,不知道对不对?要是不对为啥?谢谢了
展开
2个回答
展开全部
不对!!
堆和栈的区别
1、栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其
操作方式类似于数据结构中的栈。
2、堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回
收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表,呵呵。
通俗点:
stack存储自动变量。STACK的分配操作要比动态存储区快得多,这是因为STACK的分配只涉及到一个指针的递增,而动态存储区的分配涉及到较为复杂的管理机制。STACK中,内存一旦被分配,对象就立即被构造好了;对象一旦被销毁,分配的内存也被收回。在STACK中,没有办法直接操纵已经被分配但还没有被初始化的STAKC空间。
HEAP是一个动态存储区,使用MALLOC,new;FREE,delete以及一些相关变量来进行分配和回收。与自由存储区有些地方不同。
非动态申请的全局变量和局部变量,都存储在栈空间内,根据程序的调用关系,压栈。
动态申请的内存空间都是从堆中分出来的一块,释放的时候再还给堆。
堆和栈的区别
1、栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其
操作方式类似于数据结构中的栈。
2、堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回
收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表,呵呵。
通俗点:
stack存储自动变量。STACK的分配操作要比动态存储区快得多,这是因为STACK的分配只涉及到一个指针的递增,而动态存储区的分配涉及到较为复杂的管理机制。STACK中,内存一旦被分配,对象就立即被构造好了;对象一旦被销毁,分配的内存也被收回。在STACK中,没有办法直接操纵已经被分配但还没有被初始化的STAKC空间。
HEAP是一个动态存储区,使用MALLOC,new;FREE,delete以及一些相关变量来进行分配和回收。与自由存储区有些地方不同。
非动态申请的全局变量和局部变量,都存储在栈空间内,根据程序的调用关系,压栈。
动态申请的内存空间都是从堆中分出来的一块,释放的时候再还给堆。
参考资料: 找的地方太多了
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询