我已经对 Android native 库进行了更改并安装了新的 system.img 文件,但现在在启动时遇到了不相关的错误。我可以通过吞下错误来克服它,但我想知道是否有人可以解释问题所在。
The Android implementation of Logger.java claims它强制初始化 LogManager,因为它的类初始化代码执行必要的一次性设置。但是这种强制初始化会导致 NoClassDefFoundError。我认为这与 Zygote 尚未预加载的类有关,但我对整个类加载器和 VM 业务不太熟悉。
如果有人有一些见解,将不胜感激。谢谢。
I/Zygote ( 1253): Preloading classes...
D/skia ( 1253): ------ build_power_table 1.4
D/skia ( 1253): ------ build_power_table 0.714286
W/dalvikvm( 1253): Exception Ljava/lang/StackOverflowError; thrown during Ljava/util/logging/LogManager;.<clinit>
W/dalvikvm( 1253): Exception Ljava/lang/NoClassDefFoundError; thrown during Ljava/security/Security;.<clinit>
W/dalvikvm( 1253): Exception Ljava/lang/ExceptionInInitializerError; thrown during Landroid/net/http/HttpsConnection;.<clinit>
E/Zygote ( 1253): Error preloading android.net.http.HttpsConnection.
E/Zygote ( 1253): java.lang.ExceptionInInitializerError
E/Zygote ( 1253): at java.lang.Class.classForName(Native Method)
E/Zygote ( 1253): at java.lang.Class.forName(Class.java:237)
E/Zygote ( 1253): at java.lang.Class.forName(Class.java:183)
E/Zygote ( 1253): at com.android.internal.os.ZygoteInit.preloadClasses(ZygoteInit.java:295)
E/Zygote ( 1253): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:590)
E/Zygote ( 1253): at dalvik.system.NativeStart.main(Native Method)
E/Zygote ( 1253): Caused by: java.lang.ExceptionInInitializerError
E/Zygote ( 1253): at javax.net.ssl.KeyManagerFactory$1.run(KeyManagerFactory.java:57)
E/Zygote ( 1253): at javax.net.ssl.KeyManagerFactory$1.run(KeyManagerFactory.java:56)
E/Zygote ( 1253): at java.security.AccessController.doPrivilegedImpl(AccessController.java:264)
E/Zygote ( 1253): at java.security.AccessController.doPrivileged(AccessController.java:84)
E/Zygote ( 1253): at javax.net.ssl.KeyManagerFactory.getDefaultAlgorithm(KeyManagerFactory.java:55)
E/Zygote ( 1253): at org.apache.harmony.xnet.provider.jsse.SSLParameters.(SSLParameters.java:142)
E/Zygote ( 1253): at org.apache.harmony.xnet.provider.jsse.SSLContextImpl.engineInit(SSLContextImpl.java:82)
E/Zygote ( 1253): at android.net.http.HttpsConnection.initializeEngine(HttpsConnection.java:101)
E/Zygote ( 1253): at android.net.http.HttpsConnection.(HttpsConnection.java:65)
E/Zygote ( 1253): ... 6 more
E/Zygote ( 1253): Caused by: java.lang.NoClassDefFoundError: java.util.logging.LogManager
E/Zygote ( 1253): at java.util.logging.Logger.initHandler(Logger.java:419)
E/Zygote ( 1253): at java.util.logging.Logger.log(Logger.java:1094)
E/Zygote ( 1253): at java.util.logging.Logger.warning(Logger.java:906)
E/Zygote ( 1253): at org.apache.harmony.luni.util.MsgHelp.loadBundle(MsgHelp.java:61)
E/Zygote ( 1253): at org.apache.harmony.luni.util.Msg.getString(Msg.java:60)
E/Zygote ( 1253): at java.io.BufferedInputStream.read(BufferedInputStream.java:316)
E/Zygote ( 1253): at java.io.FilterInputStream.read(FilterInputStream.java:138)
E/Zygote ( 1253): at java.io.BufferedInputStream.fillbuf(BufferedInputStream.java:157)
E/Zygote ( 1253): at java.io.BufferedInputStream.read(BufferedInputStream.java:243)
E/Zygote ( 1253): at java.util.Properties.load(Properties.java:302)
E/Zygote ( 1253): at java.security.Security$1.run(Security.java:80)
E/Zygote ( 1253): at java.security.Security$1.run(Security.java:67)
E/Zygote ( 1253): at java.security.AccessController.doPrivilegedImpl(AccessController.java:264)
E/Zygote ( 1253): at java.security.AccessController.doPrivileged(AccessController.java:84)
E/Zygote ( 1253): at java.security.Security.(Security.java:66)
E/Zygote ( 1253): ... 15 more
W/dalvikvm( 1253): threadid=3: thread exiting with uncaught exception (group=0x2aac6170)
最佳答案
我认为关键实际上是这一行:
W/dalvikvm(1253):异常 Ljava/lang/StackOverflowError;在 Ljava/util/logging/LogManager 期间抛出;
我猜有一个 <clinit>
在该行的末尾,HTML 转换被吞没了。该消息说,在 LogManager 类的类初始化期间,出现 StackOverflowError。这导致该类不可用。后来,当调用 Logger.initHandler() 时,系统返回了 NoClassDefFoundError。
因此,要弄清楚发生了什么,您需要处理 StackOverflowError。
关于java - 在 Android Dalvik VM 中加载 java.util.logging.LogManager 的类初始化问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2472289/