下载此文档

JAVA虚拟机内存分配与回收机制.docx


文档分类:论文 | 页数:约4页 举报非法文档有奖
1/4
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/4 下载此文档
文档列表 文档介绍
JAVA虚拟机内存分配与回收机制.docxJAVA虚拟机内存分配与回收机制Java把内存划分成两种:一种是栈内存,一种是堆内存。在函数中定义的一些基本类型的变量和对彖的引用变量都在函数的栈内存中分配。当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动釋放掉为该变量所分配的内存空间,该内存空间可以立即被另作他用。堆内存川来存放由new创建的对象和数组。在堆中分配的内存,。在堆中产牛了一个数组或对彖后,还可以在栈中定义一个特殊的变量,让栈中这个变量的取值等于数组或对象在堆内存中的首地址,栈中的这个变量就成了数组或对象的引川变量。引用变最就相当于是为数组或对象起的一个名称,以厉就对以在程序中使用栈中的引用变量來访问堆中的数组或对象。具体的说:栈与堆都是Java用来在Ram屮存放数据的地方。与C++不同,Java自动管理栈和堆,程序员不能直接地设置栈或堆。Java的堆是一个运行时数据区,类的(对象从屮分配牢间。、anewarray和multianewarray等指令建立,它们不需要程序代码来显式的禅放。堆是由垃圾回收来负责的,堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是在运行时动态分配内存的,Java的垃圾收集器会自动收走这些不再使用的数据。但缺点是,由于要在运行吋动态分配内存,存取速度较慢。栈的优势是,存取速度比堆要快,仅次于寄存器,栈数据可以共享。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。栈中主要存放一些基本类型的变量(,int,short,long,byte,float,double,boolean,char)和对象句柄。栈有一个很重要的特殊性,就是存在栈屮的数据可以共享。假设我们同时定义:inta=3;intb二3;编译器先处理inta=3;首先它会在栈中创建一个变量为a的引用,然后査找栈中是否有3这个值,如果没找到,就将3存放进來,然后将a指向3。接着处理intb二3;在创建完b的引用变量后,因为在栈中已经有3这个值,便将b直接指向3。这样,就出现了a与b同时均指向3的情况。这时,如果再令a二4;那么编译器会重新搜索栈屮是否有4值,如果没有,则将4存放进来,并令a指向4;如果已经有了,则直接将a指向这个地址。因此a值的改变不会影响到b的值。要注意这种数据的共享与两个对象的引川同时指向一个对彖的这种共享是不同的,因为这种情况a的修改并不会影响到b,它是市编译器完成的,它有利于节省空间。而一个对彖引用变量修改了这个对彖的内部状态,会彩响到另一个对象引用变量。String是一个特殊的包装类数据。可以用:Stringstr=newStringC'abc^);Stringstr="abc";两种的形式来创建,第一种是用new()来新建对象的,它会在存放于堆中。每调用一次就会创建一个新的对象。而第二种是先在栈中创建一个对String类的对象引用变量str,然后杳找栈中有没有存放〃abc〃,如果没有,则将〃abc"存放进栈,并令str指向“abc”,如果已经有“abc”贝|J直接令str指向“abc”。比较类里面的数值是否相等时,用equals()方法;当测试两个包装类的引用是否指向同一个对象时,川二二,下面川例子说明上而的理

JAVA虚拟机内存分配与回收机制 来自淘豆网m.daumloan.com转载请标明出处.

非法内容举报中心
文档信息
  • 页数4
  • 收藏数0 收藏
  • 顶次数0
  • 上传人小博士
  • 文件大小58 KB
  • 时间2019-07-18
最近更新