Java 静态块抛异常之后

一 背景

一直以为Java静态块抛异常,没人捕获,虚拟机会推出,要不是最近debug到异常的执行流程,观念还正不了,自己看吧。

 

二 代码

(1)静态块抛异常类

/**
 * 静态块抛异常类
 */
public class App {

    static {
        System.out.println("static start !=============");
        if (true) {
            throw new RuntimeException("static test");
        }
        System.out.println("static finiah!=============");
    }

    public static void hello() {
        System.out.println("hello ! ");
    }
}

 

(2)调用类

/**
 * 调用静态块
 */
public class TestApp {
    public static void main(String[] args) {
        try {
            App.hello();
        } catch (Throwable e) {
            System.err.println("excepiton1 start : =========" );
            e.printStackTrace();
            System.err.println("excepiton1 finish! =========");
        }

        System.err.println("--------------------------------");
        try {
            App.hello();
        } catch (Throwable e) {
            System.err.println("excepiton2 start ! =========");
            e.printStackTrace();
            System.err.println("excepiton2 finish! =========");
        }
    }
}

 

三 执行结果

 

static start !=============
excepiton1 start : =========
java.lang.ExceptionInInitializerError
	at x.test.TestApp.main(TestApp.java:9)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at com.intellij.rt.execution.application.AppMain.main(AppMain.java:147)
Caused by: java.lang.RuntimeException: static test
	at x.test.App.<clinit>(App.java:11)
	... 6 more
excepiton1 finish! =========
--------------------------------
excepiton2 start ! =========
java.lang.NoClassDefFoundError: Could not initialize class x.test.App
	at x.test.TestApp.main(TestApp.java:18)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at com.intellij.rt.execution.application.AppMain.main(AppMain.java:147)
excepiton2 finish! =========

 

四 说明

1)静态块在类首次使用时加载类后调用,如果调用过程产生异常,会抛到首次调用处,可以捕获。

2)后续调用该类,会出现找不到类异常

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值