在本文中,简单的为大家介绍有关,java中变量在内存是如何分配的。

  在任何编程语言中,无论是基本类型还是引用类型,不论其作用域如何,都必须为其分配一定的内存空间,Java 语言也不例外,Java 的数据类型可以分为两种:基本类型(变量持有数据本身的值)和引用类型(是某个对象的引用,而并非是对象本身);基本类型包括:boolean、float、double、int、long、short、byte以及char;在Java编程语言中除基本类型以外其余都是引用类型如:类类型、数组类型等。

  在计算机内存中主要来自四个地方:heap segment(堆区)、stack segment(栈区)、codesegment(代码区)、data segment(数据区);不同的地方存放不同数据:其中堆区主要存放Java程序运行时创建的所有引用类型都放在其中;栈区主要存放Java程序运行时所需的局部变量、方法的参数、对象的引用以及中间运算结果等数据;代码区主要存放Java的代码;数据区主要存放静态变量及全局变量;以下结合实例来探讨其具体机制。


class Student {
 private String name;
 private int age;
 public Student(String name, int age) {
  this.name = name;
  this.age = age;
 }
}
public class Test {
 static int i = 10;
 public static void main(String[] args) {
  Student s1 = new Student(“feng”, 21);
 }
}


  当该程序运行起来后,其计算机内存分布大致如下:

  对象在内部表示Java虚拟机规范并没有规定其在堆中是如何表示的。对象的内部的表示会直接影响到堆区的设计以及垃圾收集器(GC)的设计。

  Java在堆中的表示方法具体有两种:

  把堆分成两个部分:一个句柄池,一个对象池;表示如下图所示:

  用对象指针直接指向一组数据,而该数据包括对象实例数据以及指向方法区中的数据的指针,具体如下图所示:

  小结:通过对对象内存分配的分析,来使读者对Java的底层有一个比较理性的认识,从而进一步掌握Java的基础知识。在深入了解了Java内存的分配以后,才能为以后编写高质量的程序打下坚实的基础,而且可以借鉴该思想来分析其它面向对象语言的内存分配问题。