A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

我了解的就以下一些,有不足的请大家多多指教!
按照编译原理的观点,程序运行时的内存分配有三种策略,分别是静态的,栈式的,堆式的。
栈式存储分配也称为动态存储分配,是由一个类似堆栈的运行栈来实现的。和静态存储方案中,程序对数据区的需求在编译时是完全未知的,只有运行的时候才能够知道,但是规定在运行中进入一个程序模块时,必须知道该模块所需的数据区大小才能够为其分配内存。栈式存储分配按照先进后出的原则进行分配。
从栈和堆的功能和作用来通俗的比较,堆主要用来存放对象的,栈主要用来执行程序的。
在java中,在函数中定义的一些基本类型的变量和对象的引用变量都在函数的栈内存中分配。
当在一段代码块定义一个变量时,java就在栈中为变量分配内存空间,当超过变量的作用域后,java会自动释放掉为该变量所分配的内存空间,该内存空间可以立即被另作他用。
堆内存用来存放有new创建的对象和数组。
栈中主要存放一些基本类型的变量(int,short,long,float,double,boolean,char)和对象句炳。

在堆中分配的内存,由java虚拟机的自动垃圾回收器来管理。
在堆中产生了一个数组或对象后,还可以在栈中定义一个特殊的变量,让栈中这个变量的取值等于数组或对象在堆中内存中的首地址,栈中的变量就成了数组或对象的引用变量。
引用变量就相当于是为数组或对象起的一个名称,以后就可以在程序中使用栈中的引用变量来访堆中的数组或对象。
堆的优势:可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是在运行时动态分配内存的,java的垃圾收集器会自动收走这些不再使用的数据。
    缺点:存取速度较慢(由于要在运行时动态分配内存)。
栈的优势:存取速度比堆要快,仅次于寄存器,栈数据可以共享。
缺点:存在栈中的数据大小与生存期必须确定的,缺乏灵活性。

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马