黑马程序员技术交流社区
标题:
堆和栈
[打印本页]
作者:
赵刘滨
时间:
2012-8-4 18:40
标题:
堆和栈
堆和栈的区别是什么?
作者:
梁健1
时间:
2012-8-5 09:32
区别我也不太明白,但是全局变量定义之后是在绽中存放,new一个对象是在堆中存放;
作者:
刘玉
时间:
2012-8-5 10:33
你可以把栈区想想成书本的目录,把堆区想象成书本的内容
作者:
赵刘滨
时间:
2012-8-5 19:22
他们二者的本质区别在于堆相等于值类型,栈相等于引用类型。前者的值会发生改变,而后者的值不会发生改变。
作者:
郭张浩
时间:
2012-8-6 03:34
这是一个前辈写的,非常详细
int a = 0; 全局初始化区
char *p1; 全局未初始化区
main()
{
int b; 栈
char s[] = "abc"; 栈
char *p2; 栈
char *p3 = "123456"; 123456\0在常量区,p3在栈上。
static int c =0; 全局(静态)初始化区
p1 = (char *)malloc(10);
p2 = (char *)malloc(20);
分配得来得10和20字节的区域就在堆区。
strcpy(p1, "123456"); 123456\0放在常量区,编译器可能会将它与p3所指向的"123456"优化成一个地方。
}
作者:
冯华亮
时间:
2012-8-6 12:52
栈是程序编译时就分配好的内存大小,所以你的程序中必须明确栈的内存大小,而堆是在程序运行动态分配的内存空间,它是根据程序员需要动态分配内存的、
作者:
李承伟
时间:
2012-8-6 13:07
堆通常是一个可以被看做一棵树的数组对象
堆总是满足下列性质:
1) 堆中某个节点的值总是大于或小于其父节点的值;
2) 堆总是一颗完全树
将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。常见的堆有二叉堆、斐波那契堆等。
栈也可称堆栈按照后进先出的原理运作
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2