C++类实例的内存分配有几种方式,可不可以放在堆栈上。

希望如果能详细越详细,越好,但不要复制一些没用的。哪还不如简单些。答得好再追加分数,呵呵,先谢谢了呵呵,我自己找到一个例子,还希望有人能给个系统的回答http://zhi... 希望如果能详细越详细,越好,但不要复制一些没用的。哪还不如简单些。答得好再追加分数,呵呵,先谢谢了
呵呵,我自己找到一个例子,还希望有人能给个系统的回答
http://zhidao.baidu.com/question/18578633.html
展开
 我来答
踏岸寻柳
2009-07-31 · TA获得超过6912个赞
知道小有建树答主
回答量:1776
采纳率:0%
帮助的人:634万
展开全部
可以放在堆上,也可以放在栈上。
栈上的数据操作、维护比较方便,但栈空间有限;
堆上的数据操作、维护稍微麻烦些,较容易出现内存泄露、越界、空指针等致命问题。
凄夜暗淡
2009-07-31 · TA获得超过266个赞
知道答主
回答量:85
采纳率:0%
帮助的人:98.6万
展开全部

参考资料: http://hi.baidu.com/ilotus_y/blog/item/30f1a9300495d29ea8018ee7.html

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
赛尔那加族长
2009-07-31
知道答主
回答量:17
采纳率:0%
帮助的人:12.2万
展开全部
在C++中,内存分成5个区,他们分别是堆、栈、自由存储区、全局/静态存储区和常量存储区。
堆与栈:管理方式:对于栈来讲,是由编译器自动管理,无需我们手工控制;对于堆来说,释放工作由程序员控制,容易产生memory leak。
空间大小:一般来讲在32位系统下,堆内存可以达到4G的空间,从这个角度来看堆内存几乎是没有什么限制的。但是对于栈来讲,一般都是有一定的空间大小的,例如,在VC6下面,默认的栈空间大小是1M(好像是,记不清楚了)。
碎片问题:对于堆来讲,频繁的new/delete势必会造成内存空间的不连续,从而造成大量的碎片,使程序效率降低。对于栈来讲,则不会存在这个问题,因为栈是先进后出的队列,他们是如此的一一对应,以至于永远都不可能有一个内存块从栈中间弹出,在他弹出之前,在他上面的后进的栈内容已经被弹出,详细的可以参考数据结构,这里我们就不再一一讨论了。
生长方向:对于堆来讲,生长方向是向上的,也就是向着内存地址增加的方向;对于栈来讲,它的生长方向是向下的,是向着内存地址减小的方向增长。
分配方式:堆都是动态分配的,没有静态分配的堆。栈有2种分配方式:静态分配和动态分配。静态分配是编译器完成的,比如局部变量的分配。动态分配由alloca函数进行分配,但是栈的动态分配和堆是不同的,他的动态分配是由编译器进行释放,无需我们手工实现。
分配效率:栈是机器系统提供的数据结构,计算机会在底层对栈提供支持:分配专门的寄存器存放栈的地址,压栈出栈都有专门的指令执行,这就决定了栈的效率比较高。堆则是C/C++函数库提供的,它的机制是很复杂的,例如为了分配一块内存,库函数会按照一定的算法(具体的算法可以参考数据结构/操作系统)在堆内存中搜索可用的足够大小的空间,如果没有足够大小的空间(可能是由于内存碎片太多),就有可能调用系统功能去增加程序数据段的内存空间,这样就有机会分到足够大小的内存,然后进行返回。显然,堆的效率比栈要低得多。
无论是堆还是栈,都要防止越界现象的发生(除非你是故意使其越界),因为越界的结果要么是程序崩溃,要么是摧毁程序的堆、栈结构.

虽然栈有如此众多的好处,但是由于和堆相比不是那么灵活,有时候分配大量的内存空间,还是用堆好一些。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式