static {
MessageDigest d;
try {
d = java.security.MessageDigest.getInstance("MD80"); <-- MD80 is no valid algorithm
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException(e);
}
hasher = d;
}
当类加载到JVM中时,JVM将自动执行这些静态初始化语句。这意味着,在加载时抛出了runtimeexception
异常。
现在,如果我运行这样一个类(通过eclipse),我会从控制台中的静态块中获得大量异常。
Exception in thread "main" java.lang.ExceptionInInitializerError
Caused by: java.lang.RuntimeException: java.security.NoSuchAlgorithmException: MD8 MessageDigest not available
at BloomFilter.<clinit>(BloomFilter.java:86)
Caused by: java.security.NoSuchAlgorithmException: MD8 MessageDigest not available
at sun.security.jca.GetInstance.getInstance(GetInstance.java:142)
at java.security.Security.getImpl(Security.java:659)
at java.security.MessageDigest.getInstance(MessageDigest.java:129)
at BloomFilter.<clinit>(BloomFilter.java:84)
但是,这是怀疑。在“加载时间”抛出此异常。 它是如何在运行时在控制台中显示的? 这个例外被抛出并存储在'load'和'runtime'之间吗?
基本上我想了解一旦在静态块中抛出异常,'loadtime和runtime'之间会发生什么?
答案 0 :(得分:2)
此异常在运行时抛出。没有存储异常的概念。基本上静态初始化块只是在第一次加载类时逐行顺序执行,即引用类/创建对象等。
我认为按加载时间表示编译时间。在编译时,编译器只会检查你的java代码是否在语法上是正确的。它不会执行任何代码。它只会编译你的代码并为你准备字节代码,即.class文件。
答案 1 :(得分:2)
没有“加载时间”这样的东西 - 只有“运行时”。当JVM启动时,它确定需要加载哪些类;静态初始化只在需要时执行;例如,在加载课程之后。