class Point{
double x,y,z;
Point(double _x,double _y,double _z){
x = _x;
y = _y;
z = _z;
}
void setX(double _x){
x = _x;
}
double getDistance(Point p){
return (x - p.x)*(x- p.x) + (y - p.y)*(y-p.y)+ (z - p.z) * (z - p.z);
}
}
public class TestPoint{
public static void main(String[] args){
Point p = new Point(1.0,2.0,3.0);
Point p1 = new Point(0.0,0.0,0.0);
System.out.println(p.getDistance(p1));
p.setX(5.0);
System.out.println(p.getDistance(new Point(1.0,1.0,1.0)));
}
}
以上代码是两个类名分别为Point和TestPoint的类,接着我们通过图解来分析类创建对象的内存。
首先我们先要了解,栈空间中存放的是对象的引用,而堆空间中存放的是new出来的东西,栈、堆两个空间通过一个内存地址相互连接。
1、Point p = new Point(1.0,2.0,3.0);
在这段代码中,首先我们定义了一个p,这是一个局部变量,所以在栈内存空间里有一个p局部变量,然后new了一个point的对象,在堆内存中为对象分配内存。那么在内存中的图解即可如下:
2、Point p1 = new Point(0.0,0.0,0.0);
在这段代码中,首先我们定义了一个p1,这是一个局部变量,所以在栈内存空间里有一个p1局部变量,然后new了一个point的对象,在堆内存中为对象分配内存。执行到这一步,内存中空间如图所示:
3、System.out.println(p.getDistance(p1));
在这段代码中,我们需要打印一个p,但是这个p和第一个p不是同一个p,需要创建一个point对象,栈空间中存放的是对象的引用,而堆空间中存放的是new出来的东西
词句代码执行完,打印出结果后,p:yy和指针就会消失,占用的内存就会被重新分配,内存分配图会回复到图2所示。
4、p.setX(5.0);
在这段代码中,会调用setX()方法,然后将5.0赋给_x,然后5.0又会传给x,接着会将局部变量p所指向的堆中的对象的x值改为5.0.
5、System.out.println(p.getDistance(new Point(1.0,1.0,1.0)));
这句代码中,也会重新创建一个新的point对象p。由于getDistance的参数是一个表达式,所以需要先计算参数表达式,此表达式相当于在堆中new了一个新的对象,然后将栈中存放的对象引用地址指向它。
另外此句代码执行完后,为此局部变量分配的空间消失,指向这个对象的引用消失,堆中对象也会被垃圾回收机制回收。
最后TestPoint方法执行完后,为TestPoint方法的变量分配的空间也都会清空,内存回归原始。
结语
在上一篇博客中,我们大体了解了JVM以及程序运行内存分配问题,其中提到了Java的垃圾回收机制,这是一个神奇的存在,也正是Java的垃圾回收机制的存在,TestPoint方法执行完后,内存会回归原始。
欲知后事如何,请听下回分解!