6.3 对象的内存体现
最后更新于:2022-04-01 14:10:58
这一节我们来简单的看一看对象在内存中是什么样子呢,如何体现。
我们以上一节的测试代码为例。
我们在函数的内存分配分析过,当该代码运行时,首先会加载主函数在栈内存中为main函数分配一个空间;
然后运行函数中的第一行语句,Car myCar = new Car();
然后把局部变量myCar加载到栈内存,然后通过new在堆内存中分配空间,然后把这个地址赋给变量myCar;
我们看一看是不是这样
~~~
class CarDemo
{
public static void main(String[] args)
{
//在计算中创建一个car的实例,通过new这个关键字.
Car myCar = new Car();//myCar就是一个类类型的引用变量,指向了该类的对象.
System.out.println(myCar);
}
}
~~~
结果:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-05-18_573c41725e301.jpg)
我们看到了myCar所指的位置,这里我们就这是我们小汽车的车库吧,它就在139a55这个地方.
而在上面的堆内存中会对象的属性变量num,color,brand这些变量,由于堆内存中的变量会默认初始化,上面的变量会被默认初始化;
num=0,color=null,brand=null;
此时如果我们没不做2-4行语句,而是直接运行myCar.start(),我们看看结果如下:
~~~
class CarDemo
{
public static void main(String[] args)
{
//在计算中创建一个car的实例,通过new这个关键字.
Car myCar = new Car();//myCar就是一个类类型的引用变量,指向了该类的对象.
//myCar.num = 4;
//myCar.color = "red";
//myCar.brand = "BWM";
myCar.start();
myCar.run();//要使用对象中的内容,可能通过 对象.成员 的形式来完成调用.
}
}
~~~
结果:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-05-18_573c41ae6cc6a.jpg)
我们看到了三个属性被默认初始化了,那么就是说我们没有给属性赋值,系统也会为我们打造一辆空皮汽车的.
那么再来看一下当们赋值之后,我们再来看一下我们的汽车是什么样子:
~~~
class CarDemo
{
public static void main(String[] args)
{
//在计算中创建一个car的实例,通过new这个关键字.
Car myCar = new Car();//myCar就是一个类类型的引用变量,指向了该类的对象.
myCar.num = 4;
myCar.color = "red";
myCar.brand = "BWM";
myCar.start();
myCar.run();//要使用对象中的内容,可能通过 对象.成员 的形式来完成调用.
}
}
~~~
结果:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-05-18_573c41ae7f3c4.jpg)
我们看到程序会先分别给num,color,brand这三个属性赋值,也就是说我们得到了一个完完整整的宝马汽车,而存放这辆车的地址没有发生变化,还是原来堆内存中的地址值.
同理如果我们创建多个car的实例,内存中的加载过程都是一样的,它们都有各自不同的空间和对应的地址.