【Java基础】类的实例化、static、父类构造函数执行顺序
2015-12-14 20:06
525 查看
重温java基础,以免自己以后犯原则性错误,这是最基本,最基础的东西。
先看结论:
一个类的实例化过程:
1,首先会执行类中static代码块(不管代码块是否在类的开头还是末尾处),如果这个类有父类,同样会优先查找父类中的static代码块,然后是当前类的static。(staitc类加载到内存中时就已经分配空间,赋值了)
2,然后会从父类的第一行开始执行,直至代码末尾处,中间不管是有赋值还是method调用,都会按顺序一一执行(method),普通代码块{ }...
也就是说在new对象的时候,先给私有数据成员分配存储空间赋值(从上往下执行),接着才执行构造方法里的代码。
3,其次才是父类的构造函数,执行带参数或不带参数的构造函数,依赖于实例化的类的构造函数有没有super父类的带参或不带参的构造函数,上边试验二三已经证明。
4,然后会从子类(当前类)的第一行开始执行,直至代码末尾处,中间不管是有赋值还是method调用,都会按顺序一一执行(method),普通代码块{ }...
5,其次会是子类(当前类)的构造函数,按顺序执行。
6,最后是类方法的调用执行,如果子类覆盖了父类的method,执行时会先执行子类覆盖的method,method内如果有super.method(),才会调用父类的同名method,否则不会。
代码部分:
A.java
B类
测试类一:
实验一
思考一下打印输出的顺序?
打印输出结果:
main app run..
I`m a static {} from class A..
I`m a static {} from class B..
getA2..
top of A() a1=8 a2=7 a3=9
below A()..has start
A 带参数构造函数: 66
A 构造函数
getB2..
top of B() b1=0 b2=33 b3=5
below B()..has start
B 带参数构造函数:33
B 构造函数
methoaA int class B
methodA
分析:B类无参的构造函数中的this语句并没有影响到父类A类的构造函数执行顺序
**********************************分割线***********************************
实验二
结果:
I`m a static {} from class A..
method hahahah
method1 hahahah
static成员变量 以及static代码块在代码加载后就执行了。 而且加载只加载了一次。
先看结论:
一个类的实例化过程:
1,首先会执行类中static代码块(不管代码块是否在类的开头还是末尾处),如果这个类有父类,同样会优先查找父类中的static代码块,然后是当前类的static。(staitc类加载到内存中时就已经分配空间,赋值了)
2,然后会从父类的第一行开始执行,直至代码末尾处,中间不管是有赋值还是method调用,都会按顺序一一执行(method),普通代码块{ }...
也就是说在new对象的时候,先给私有数据成员分配存储空间赋值(从上往下执行),接着才执行构造方法里的代码。
3,其次才是父类的构造函数,执行带参数或不带参数的构造函数,依赖于实例化的类的构造函数有没有super父类的带参或不带参的构造函数,上边试验二三已经证明。
4,然后会从子类(当前类)的第一行开始执行,直至代码末尾处,中间不管是有赋值还是method调用,都会按顺序一一执行(method),普通代码块{ }...
5,其次会是子类(当前类)的构造函数,按顺序执行。
6,最后是类方法的调用执行,如果子类覆盖了父类的method,执行时会先执行子类覆盖的method,method内如果有super.method(),才会调用父类的同名method,否则不会。
代码部分:
A.java
public class A { int a1 = 8; int a2 = getA2(); { int a3 = 9; System.out.println("top of A() a1=" + a1 + " a2=" + a2 + " a3=" + a3); } public A() { this(66); System.out.print("A 构造函数\n"); } { System.out.println("below A()..has start"); } public A(int num) { System.out.print("A 带参数构造函数: " + num + "\n"); } static { System.out.println("I`m a static {} from class A.."); } int getA2() { System.out.println("getA2.."); return 7; } public void methodA() { System.out.println("methodA"); } public static void method() { System.out.println("hahaha"); } public static void method1() { System.out.println("hahaha"); } }
B类
public class B extends A { int b1 = 0; int b2 = getB2(); { int b3 = 5; System.out.println("top of B() b1=" + b1 + " b2=" + b2 + " b3=" + b3); } public B() { this(33); // super(44);//添加super语句,会导致实例化时直接执行父类带参数的构造函数 System.out.print("B 构造函数\n"); } public B(int num) { // 添加super语句,会导致实例化时直接执行父类带参数的构造函数 // 前提是带参数的构造函数B会被运行(new实例化或this) // super(77); System.out.print("B 带参数构造函数:" + num + "\n"); } { System.out.println("below B()..has start"); } static { System.out.println("I`m a static {} from class B.."); } int getB2() { System.out.println("getB2.."); return 33; } @Override public void methodA() { System.out.println("methoaA int class B"); super.methodA(); } }
测试类一:
public class mymain { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub System.out.println("main app run.."); B b = new B(); // B b = new B(22); b.methodA(); } }
实验一
思考一下打印输出的顺序?
打印输出结果:
main app run..
I`m a static {} from class A..
I`m a static {} from class B..
getA2..
top of A() a1=8 a2=7 a3=9
below A()..has start
A 带参数构造函数: 66
A 构造函数
getB2..
top of B() b1=0 b2=33 b3=5
below B()..has start
B 带参数构造函数:33
B 构造函数
methoaA int class B
methodA
分析:B类无参的构造函数中的this语句并没有影响到父类A类的构造函数执行顺序
**********************************分割线***********************************
实验二
public class mymain { public static void main(String[] args) { A.method(); A.method1(); } }
结果:
I`m a static {} from class A..
method hahahah
method1 hahahah
static成员变量 以及static代码块在代码加载后就执行了。 而且加载只加载了一次。
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树
- [原创]java局域网聊天系统