面向对象——创建对象内存分析
针对以下程序进行简单分析:
package(包)com.du.OOP.demo02:类Application(mian()方法)
package com.du.OOP.demo02;
import com.du.OOP.demo03.Pet;
//一个项目应该只存在一个main方法
public class Application {
public static void main(String[] args) {
Pet dog = new Pet();
dog.name = "旺财";
dog.age = 3;
dog.shout();
Pet cat = new Pet();
}
}
package(包)com.du.OOP.demo03:类Pet(创建对象内存简单分析)
package com.du.OOP.demo03;
public class Pet {
public String name;//使用public在main()方法中才能调用name和age属性
public int age;
//无参构造
public void shout(){
System.out.println("叫了一声!");
}
}
内存概念:
主要分为堆和栈,堆中又包含一个方法区
分析:
- 首先在方法区加载Application类中的main()方法,执行main()方法(压入栈中)

- new Pet(dog),此时将Pet类加载到方法区

- 生成一个具体对象:dog,引用变量名存放在栈中,真正的对象存放在堆中,默认name = null,默认age = 0,方法shout()是调用的方法区Pet类中的shout()方法

- 此时在main()方法给dog中的name、age进行赋值

- 此时进行new Pet(cat),操作与new Pet(dog)相同

本文通过一个简单的Java程序示例,分析了面向对象编程中对象的创建过程及其在内存中的分布。在main方法中,首先创建了一个Pet类型的对象dog,接着给其name和age属性赋值,并调用shout()方法。随后,又创建了另一个Pet对象cat。内存中,对象实例存储在堆中,引用变量存储在栈中,属性值与方法存在于堆的相应对象中。此程序涉及Java内存管理的基础知识,包括堆栈内存结构及对象生命周期。
753

被折叠的 条评论
为什么被折叠?



