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的实例,内存中的加载过程都是一样的,它们都有各自不同的空间和对应的地址.
';