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”和“运行时”之间?
基本上,我希望了解在静态块中抛出异常后,在“加载时间”和“运行时”之间会发生什么?
发布于 2015-03-08 14:35:23
没有“加载时间”这样的东西--只有“运行时”。当JVM启动时,它确定需要加载哪些类;只要需要,就执行静态初始化;例如,在加载类之后执行静态初始化。
发布于 2015-03-08 14:20:31
此异常是在运行时引发的。没有存储异常的概念。基本上,当第一次加载类时,静态初始化块只依次执行一次,即引用类/创建对象等。
我认为加载时间,你指的是编译时间。编译时,编译器只需检查您的java代码在语法上是否正确。它不会执行任何代码。它只需编译您的代码并为您准备字节代码,即.class文件。
https://stackoverflow.com/questions/28927420
复制相似问题