2

壁紙を選択すると、その例外が発生します。私は実際にどの機能が原因であるかわかりません。エラーログは次のとおりです。

       I/ActivityManager( 1360): Starting activity: Intent { cmp=com.android.wallpaper.livepicker/.LiveWallpaperPreview (has extras) }
       W/dalvikvm(29175): threadid=1: thread exiting with uncaught exception (group=0x40020ac0)
       E/AndroidRuntime(29175): FATAL EXCEPTION: main
       E/AndroidRuntime(29175): java.lang.IllegalStateException: AssetManager has been finalized!
       E/AndroidRuntime(29175):     at android.content.res.AssetManager.isUpToDate(Native Method)
       E/AndroidRuntime(29175):     at android.app.ActivityThread.getPackageInfo(ActivityThread.java:2350)
       E/AndroidRuntime(29175):     at android.app.ActivityThread.getPackageInfoNoCheck(ActivityThread.java:2337)
       E/AndroidRuntime(29175):     at android.app.ActivityThread.handleCreateService(ActivityThread.java:2935)
       E/AndroidRuntime(29175):     at android.app.ActivityThread.access$3300(ActivityThread.java:125)
       E/AndroidRuntime(29175):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2087)
       E/AndroidRuntime(29175):     at android.os.Handler.dispatchMessage(Handler.java:99)
       E/AndroidRuntime(29175):     at android.os.Looper.loop(Looper.java:123)
       E/AndroidRuntime(29175):     at android.app.ActivityThread.main(ActivityThread.java:4627)
       E/AndroidRuntime(29175):     at java.lang.reflect.Method.invokeNative(Native Method)
       E/AndroidRuntime(29175):     at java.lang.reflect.Method.invoke(Method.java:521)
       E/AndroidRuntime(29175):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:878)
       E/AndroidRuntime(29175):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:636)
       E/AndroidRuntime(29175):     at dalvik.system.NativeStart.main(Native Method)
       I/ActivityManager( 1360): Displayed activity com.android.wallpaper.livepicker/.LiveWallpaperPreview: 331 ms (total 331 ms)
       W/InputManagerService( 1360): Window already focused, ignoring focus gain of: com.android.internal.view.IInputMethodClient$Stub$Proxy@44bf5a08
       I/ActivityManager( 1360): Process com.bukabros.videolivewallpaper (pid 29175) has died.
       W/ActivityManager( 1360): Scheduling restart of crashed service com.bukabros.videolivewallpaper/.VideoLiveWallpaper in 5000ms
       I/ActivityManager( 1360): Start proc com.bukabros.videolivewallpaper for service com.bukabros.videolivewallpaper/.VideoLiveWallpaper: pid=29207 uid=10090 gids={}

私が考えることができる唯一のことは、壁紙が選択されたときにonCreateが正しい順序で呼び出されないことです。そこで、アセットマネージャーをインスタンス化します。

はい、私はNDKを使用していますが、アセットマネージャーはそこで使用されていません。

4

1 に答える 1

2

ああ、気にしないでください。原因は、assetmanager へのハンドルが静的変数だったことです。(それは他の何かのための簡単なハックでした)。それを通常の変数にすることで問題が解決しました。

于 2011-06-17T17:55:44.293 に答える