Java类与对象的关系可以看作是模板与实物的关系,
通过固定的模板我们可以创建出多个对象,
- 类与对象的联系可通过new关键字进行创建
- 类相关的信息存储在方法区
- 而对象的相关信息存储在堆区(堆区为每个对象分配一定的空间进行存储)
- 类里面的构造函数可以重载
- 构造函数里面的this: 因为构造函数进行使用前,对象还没有被创建 所以this表示当前对象的引用。而不是当前对象
- super() 方法在类加载的时候会检测类中是否存在无参构造方法, 没有的话会自动创建。
//定义类
public class Student{//类的首字母要大写
int id;
String name;//属性 或者叫局部变量
int age;
computer comp;//配备电脑
//方法
void study(){
System.out.println("我在网吧使用"+comp.brand+"敲代码);
}
void play(){
System.out.println("我在网吧打游戏");
}
void watch(){
System.out.println("我在网吧看电视");
}
//构造方法 无参的构造方法可以由系统自己创建
Student(){
}
public static void main(String[] args){
Sudent stu=new Student();//创建对象
stu.id=417020;//使用对象中的id属性 也可以称为局部变量
stu.name="sofency";
stu.age=18;
Computer c1=new Computer();//在main方法中准备一个电脑对象
c1.brand="DELL";//电脑的品牌是DELL
stu.comp=c1;//将c1电脑配备给该学生
stu.study();//执行学习的方法
}
class Computer{
String brand;//电脑的商标
}
}
那么代码在内存中怎么运行的哪,java的程序是在虚拟机上进行运行的。
jvm虚拟机中程序的运行主要在栈区,堆区和方法区进行操作的
下面先介绍各个区的主要功能
-
栈区的特点
1.栈是描述方法执行的内存模型,每个方法被调用时都会创建一个栈帧(主要存储局部变量,操作数,方法入口等)重点
2.jvm为每个线程创建一个栈,用来存储该线程执行方法的信息(实际参数,局部变量等)
3.栈属于线程私有,不能实现线程间的共享
4.栈是由系统自动分配,是一个连续的内存区域 -
堆的作用
1.用来存储创建好的对象和数组(数组也是对象)重点
2.jvm只有一个堆,被所有线程共享
3.堆是一个不连续的内存空间,分配灵活
当执行new 时就会在堆区产生一个堆区用来存储对象 -
方法区
1.jvm只有一个方法区,被所有线程共享
2.方法区实际上也是堆,只是用来存储类,常量相关的信息(类被加载后经常不变)
3.用来存储程序中永远不变或唯一的内容(类信息(class),静态变量,字符串常量等)
程序加载的顺序
- 程序加载的顺序首先加载静态代码块里面的数据即static(静态代码块)里面的数据,如果静态代码块有两次的赋值机会则最后的值与顺序有关。静态代码块在程序运行中只初始化一次。
- 再加载实例代码块,
- 最后再加载类对象(构造方法是最后加载的)
class testDemo {
public String name;//局部成员变量
public static int age;//静态成员变量
static{
age = 20;
System.out.println("我第一");
}
public testDemo(String name){
this.name = name;
System.out.println("我才是第一");
}
{
System.outg.println("我第二执行");
}
}
class Demo{
public static void main(String[]args){
testDemo test = new testDemo("sofency");
}
}
结果如图 很明显static第一运行的