Java技术_基础技术(0003)_类执行顺序详解+实例(阿里面试题)+详细讲解+流程图

简介:

Java技术_基础技术(0001)_后台模拟调用action

Java技术_基础技术(0002)_中间件启动class加载顺序(以tomcat为例)

Java技术_基础技术(0003)_类执行顺序详解+实例(阿里面试题)+详细讲解+流程图

Java技术_基础技术(0004)_eclipse远程调试tomcat


基础技术:

对于java类各个成员的执行顺序,现拿出阿里的面试题作为样例(例子非常好,是用心出的题),在这里重新说明一下java类执行顺序的原则。


源码下载(包含题、结果、分析过程)

一、总体原则

列出执行顺序的原则(这里本人出了简化,比较明了。可能有漏的,请帮忙补充,但应付该实例足以):

 ==父类先于子类;

 
 ==静态先于非静态;
 
 ==变量和块先于构造方法;
 
 ==变量声明先于执行(变量赋值、块执行);(这一点是根据数据在内存中是如何存储的得出的,基本类型、对象、String均不一样,但是总结起来应该是这样)
 
 ==变量赋值与块优先级相同;
 
 ==同优先级的从上至下执行;

二、实例

直接上题(小马哥的阿里,问:system.out打印结果。这里我加上了行号,方便解说):

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. public class StaticTest {  
  2.   
  3.     public static int k = 0;// 1  
  4.     public static StaticTest s1 = new StaticTest("s1");// 2  
  5.     public static StaticTest s2 = new StaticTest("s2");// 3  
  6.     public static int i = print("i");// 4  
  7.     public static int n = 99;// 5  
  8.     public int j = print("j");// 6  
  9.   
  10.     {  
  11.         print("构造块");  
  12.     }// 7  
  13.   
  14.     static {  
  15.         print("静态块");  
  16.     }// 8  
  17.   
  18.     public static int print(String s) {  
  19.         System.out.println(++k + ":" + s + "\ti=" + i + "\tn=" + n + "\tprint");  
  20.         ++n;  
  21.         return ++i;  
  22.     }  
  23.   
  24.     public StaticTest(String s) {  
  25.         System.out.println(++k + ":" + s + "\ti=" + i + "\tn=" + n  
  26.                 + "\tStaticTest");  
  27.         ++i;  
  28.         ++n;  
  29.     }// 9  
  30.   
  31.     public static void main(String[] args) {  
  32.         new StaticTest("init");  
  33.     }  
  34. }  

三、执行结果

这里不废话,直接上结果(大家都可以去试一下,这里我加上了sysoN====,一会分析时候用来对看),这一部分内容在下载的代码里也有。结果如下:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. /** 
  2.      *  
  3.      * 输出结果: 
  4.      *  
  5.      * syso1 ===="1:j       i=0     n=0     print" 
  6.      *  
  7.      * syso2 ===="2:构造块     i=1     n=1     print" 
  8.      *  
  9.      * syso3 ===="3:s1      i=2     n=2     StaticTest" 
  10.      *  
  11.      * syso4 ===="4:j       i=3     n=3     print" 
  12.      *  
  13.      * syso5 ===="5:构造块     i=4     n=4     print" 
  14.      *  
  15.      * syso6 ===="6:s2      i=5     n=5     StaticTest" 
  16.      *  
  17.      * syso7 ===="7:i       i=6     n=6     print" 
  18.      *  
  19.      * syso8 ===="8:静态块     i=7     n=99    <span style="white-space:pre">    </span>print" 
  20.      *  
  21.      * syso9 ===="9:j       i=8     n=100   <span style="white-space:pre">    </span>print" 
  22.      *  
  23.      * syso10===="10:构造块    <span style="white-space:pre">    </span>i=9        n=101   <span style="white-space:pre">    </span>print" 
  24.      *  
  25.      * syso11===="11:init   <span style="white-space:pre">    </span>i=10   <span style="white-space:pre">    </span>n=102  <span style="white-space:pre">    </span>StaticTest" 
  26.      */  

四、分析

一步一步按照上面的原则来分析,应该比较详细了,这一部分内容在下载的代码里也有。分析如下:

/**
====step1====首先声明StaticTest类的static变量并给与默认值。
*
* 故,执行1、2、3、4、5变量的声明。运行后变量如下:
*
* k=0; s1=null; s2=null; i=0; n=0; j未声明;
*
====step1 end====
*/
/**
====step2====变量声明完成后,为这些static变量赋值以及执行static块(赋值和块优先级一致,在前面的先执行).
*
* 故,执行1、2、3、4、5的赋值代码,8的块代码
*
========step2_1====当step2执行到2时,new了一个新的StaticTest对象.
* (此时2、3、4、5的赋值、8的代码都没执行,变量k被赋值为0,其余仍与step1中一致 )
* 这时,static变量已经声明(static变量是类属性,与对象无关),所以这里直接声明非static变量并给与默认值。
*
* 故,执行6变量的声明,运行后变量如下:
*
* k=0; s1=null; s2=null; i=0; n=0; j=0(s1的);
*
========step2_2====变量声明完成后,为这些非static变量赋值以及执行非static块。
*
* 故,执行6变量的赋值代码(syso1====k、n、i、j均+1),7的块代码(syso2====k、n、i均+1),运行后变量如下:
*
* k=2; s1=null; s2=null; i=2; n=2; j=1(s1的);
*
========step2_3====变量赋值、块执行完毕后,执行构造方法。
*
* 故,执行9构造方法(syso3====k、n、i均+1),运行后变量如下:
*
* k=3; s1=StaticTest对象; s2=null; i=3; n=3; j=1(s1的);
*
========step2_4====s1构造完毕后,继续执行3。同样是new一个新的StaticTest对象.
* 过程与step2_1至step2_3一致。
*
* 故,执行3(syso4====k、n、i、j(j=0)均+1;syso5====k、n、i均+1;syso6====k、n、i均+1),
* 运行后变量如下:
*
* k=6; s1=StaticTest对象; s2=StaticTest对象; i=6; n=6; j=1(s2的);
*
========step2_5====s2构造完毕后,继续执行4、5的赋值,为i和n赋值.
*
* 故,执行4(syso7====k、n、i均+1,i被重新赋值)、5(n被重新赋值)的赋值代码,运行后变量如下:
*
* k=7; s1=StaticTest对象; s2=StaticTest对象; i=7; n=99; j未声明;
*
========step2_6====static变量赋值完毕后,执行8的static块。
*
* 故,执行8(syso8====k、n、i均+1),运行后变量如下:
*
* k=8; s1=StaticTest对象; s2=StaticTest对象; i=8; n=100; j未声明;
*
====step2 end====
*/
/**
====step3====static变量及块完成后,声明非static变量并给与默认值.
*
* 故,执行6变量的声明。运行后变量如下:
*
* k=8; s1=StaticTest对象; s2=StaticTest对象; i=8; n=100; j=0(main的);
*
====step3 end====
*/
/**
====step4====非static变量声明完成后,为这些变量赋值以及执行非static块(赋值和块优先级一致,在前面的先执行)。
*
* 故,执行6的赋值代码(syso9====k、n、i均+1,j=++i),7的块代码(syso10====k、n、i均+1)。运行后变量如下 :
*
* k=10; s1=StaticTest对象; s2=StaticTest对象; i=10; n=102; j=9(main的);
*
====step4 end====
*/
/**
====step5====变量赋值、块执行完毕后,执行构造方法。
*
* 故,执行9构造方法(syso11====k、n、i均+1),运行后变量如下:
*
* k=11; s1=StaticTest对象; s2=StaticTest对象; i=11; n=103; j=9(main的);
*
====step5 end====
*/

五、执行流程图

以实例为准,绘制的图(原创图,请勿转载)。


原文地址:http://blog.csdn.net/ooppookid/article/details/42967353

相关文章
|
5月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
231 4
|
5月前
|
IDE JavaScript Java
在Java 11中,如何处理被弃用的类或接口?
在Java 11中,如何处理被弃用的类或接口?
296 5
|
5月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
281 1
|
5月前
|
Java Go 开发工具
【Java】(8)正则表达式的使用与常用类分享
正则表达式定义了字符串的模式。正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。
403 1
|
存储 Java 关系型数据库
20 个实例玩转 Java 8 Stream
20 个实例玩转 Java 8 Stream
423 0
20 个实例玩转 Java 8 Stream
|
存储 Java 关系型数据库
20 个实例玩转 Java 8 Stream,写的太好了!
先贴上几个案例,水平高超的同学可以挑战一下: 从员工集合中筛选出salary大于8000的员工,并放置到新的集合里。 统计员工的最高薪资、平均薪资、薪资之和。
20 个实例玩转 Java 8 Stream,写的太好了!
|
5月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
301 1
|
6月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
265 0
|
6月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
456 16