在Java中自由块的执行顺序

2016-02-19 10:49 10 1 收藏

下面这个在Java中自由块的执行顺序教程由图老师小编精心推荐选出,过程简单易学超容易上手,喜欢就要赶紧get起来哦!

【 tulaoshi.com - 编程语言 】

java中的自由块分为静态的自由块和非静态的自由块。 非静态自由块的执行时间是:在执行构造函数之前。 静态自由块的执行时间是:class文件加载时执行。 非静态自由块可以多次执行,只要初始化一个对象就会执行,但是静态自由块只会在类装载的时候执行一次,一般用来初始化类的静态变量的值。 每次初始化一个对象,都会导致一次非静态块的执行。 如果涉及到继承,则是:首先执行父类的非静态块,然后是父类的构造函数,接着是自己的自由块,最后是自己的构造函数。静态块的执行时机是在class文件装载的时候,class文件只会装载一次,因此静态块只会执行一次,后面再使用这个类时,不会再执行静态块。  静态块的执行时机是在class装载后的初始化阶段。如果采用ClassLoader的loadclass来仅仅装 载类而不初始化,是不会触发静态块的执行的。采用Class的forname(String)是采用了默认的initialize为true的情况,也就 是初始化了。如果使用forname(String name,boolean initialize, ClassLoader loader),设置initialize为false,则不会执行静态块。 在执行class装载后的初始化阶段包括:运行clinit方法,这个方法中就是类变量的初始化语句和静态自由块语句。这个方法是由java的编译器收集信息后生成的,不能显示的调用。

下面通过例子来说明:

父类

代码如下:

father.java

public class father {

    static{//静态块
       System.out.println("father'sSTATIC free block running");
    }

    {//非静态块
 System.out.println("father'sfree block running");
    }

    public father(){

       System.out.println("father'sconstructor running");

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

    }
}

子类

代码如下:

son.java
public class son extends father{
    static{//静态块
       System.out.println("son'sSTATIC free block running");
    }

    {//非静态块
       System.out.println("son's freeblock running");
    }

    public son() {
       // TODO Auto-generated constructor stub
       System.out.println("son'sconstructor running");
    }
}

主函数所在类

代码如下:

test.java

public class test{

      public static void main(String[] args) {

       Class f;

       try {

           System.out.println("--------beforeload father--------");

           f=Class.forName("freeblock.father");

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

           System.out.println("--------afterload father---------");        

           System.out.println("--------beforeinitial father object--------");

           f.newInstance();

           System.out.println("--------afterinitial father object--------");

       } catch (ClassNotFoundException e) {

           e.printStackTrace();

       } catch (InstantiationException e) {
           e.printStackTrace();

       } catch (IllegalAccessException e) {

           e.printStackTrace();
       }     
       Class s;

       try {

           System.out.println("-------beforeload son--------");

           s=Class.forName("freeblock.son");

           System.out.println("--------afterload son-------");

           System.out.println("--------beforeinitial son object----------");

           s.newInstance();

           System.out.println("--------afterinitial son object-----------");

       } catch (ClassNotFoundException e) {
           e.printStackTrace();
       } catch (InstantiationException e) {
           e.printStackTrace();
       } catch (IllegalAccessException e) {
           e.printStackTrace();
       }
    }
}

执行结果:

--------before loadfather--------

father's STATIC free blockrunning

--------after loadfather---------

--------before initial fatherobject--------

father's free block running

father's constructor running

--------after initial fatherobject--------

-------before load son--------

son's STATIC free block running

--------after load son-------

--------before initial sonobject----------

father's free block running

father's constructor running

son's free block running

son's constructor running

--------after initial son object-----------

来源:http://www.tulaoshi.com/n/20160219/1595865.html

延伸阅读
标签: PHP
  PHP作为一种服务器端的脚本语言,象编写简单,或者是复杂的动态网页这样的任务,它完全能够胜任。但事情不总是如此,有时为了实现某个功能,必须借助于操作系统的外部程序(或者称之为命令),这样可以做到事半功倍。 那么,是否可以在PHP脚本中调用外部命令呢?如果能,如何去做呢?有些什么方面的顾虑呢?相信你看了本文后,肯定能...
标签: word
在Word2010中删除构建基块 第1步,打开Word2010文档窗口,切换到插入功能区。在文本分组中单击文档部件按钮,然后在打开的菜单中选择构建基块管理器命令,如图1所示。 图1 选择构建基块管理器选项第2步,打开构建基块管理器对话框,在构建基块列表中选中准备删除的构建基块名称,并单击删除按钮。完成删除操作后单击关闭按钮即可...
代码如下: class Parent {     // 静态变量     public static String p_StaticField = "父类--静态变量";     // 变量(其实这用对象更好能体同这一点,如专门写一个类的实例)     //如果这个变量放在初始化块的后面,是会报错的,因为你根本没有被初始化   &nbs...
Java 5之后提供优秀的并发库util.concurrent,.Net中缺乏类似的功能。由于硬件体系发生了变化,多核时代来临,.NET中缺乏并发类库显然不合时宜。缓解这一矛盾的其中一个办法就是在往 C# 中移植java的 util.concurrent 。 java中的util.concurrent包中提供了一个类LockSupport,util.concurrent包很多关键实现需要调用LockSupport。...
标签: ASP
  利用err对象: sql="insert into table(f1,f2) values('v1','v2')" conn.execute sql if err.number<0 then response.write "出错了:"& err.description err.clear else response.write "OK" end if     

经验教程

635

收藏

40
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部