gpt4 book ai didi

java - 解决 onTouchEvent 上奇怪的 validator 拒绝类的任何想法

转载 作者:行者123 更新时间:2023-11-30 09:40:23 25 4
gpt4 key购买 nike

我的 android apk 出现一个非常奇怪的错误,只有在 galaxy 3 froyo 设备上运行它时才会出现(在模拟器和 galaxy s2 上运行良好)。

错误来自Ontouchevent 类,如果我注释掉某些代码行,错误就会消失。然而,这些行与此错误无关(那部分代码甚至没有执行)。

例如,如果我添加一行

if(sound)try{SoundManager.playSound(1,1);}catch(Exception e){e.printStackTrace();}

到 ontouchevent keydown 内的开关盒,它不会导致错误,但如果我添加其中的 6 个(不是一次),它会崩溃。

由于太长,我无法粘贴整个源代码,但错误如下:

02-25 19:11:59.893: WARN/dalvikvm(5754): VFY: invalid switch start: at 88, switch offset -32758, count 33104
02-25 19:11:59.928: WARN/dalvikvm(5754): VFY: rejected Lspaceshooter/apk/OpenGLRenderer;.onTouchEvent (Landroid/view/MotionEvent;)Z
02-25 19:11:59.928: WARN/dalvikvm(5754): Verifier rejected class Lspaceshooter/apk/OpenGLRenderer;
02-25 19:11:59.928: DEBUG/AndroidRuntime(5754): Shutting down VM
02-25 19:11:59.928: WARN/dalvikvm(5754): threadid=1: thread exiting with uncaught exception (group=0x4001d7d0)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): FATAL EXCEPTION: main
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): java.lang.VerifyError: spaceshooter.apk.OpenGLRenderer
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at spaceshooter.apk.Main.onCreate(Main.java:84)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.app.ActivityThread.access$2300(ActivityThread.java:125)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.os.Handler.dispatchMessage(Handler.java:99)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.os.Looper.loop(Looper.java:123)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at android.app.ActivityThread.main(ActivityThread.java:4627)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at java.lang.reflect.Method.invokeNative(Native Method)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at java.lang.reflect.Method.invoke(Method.java:521)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
02-25 19:11:59.943: ERROR/AndroidRuntime(5754): at dalvik.system.NativeStart.main(Native Method)

有什么想法吗?

最佳答案

似乎代码中的某些类只是包含太多 validator 的行。该问题仅在android 2.2 或以下系统上出现。

该解决方案似乎将类切割成更小的类并在原始类中调用它们。看起来有点愚蠢,但它确实有效。

关于java - 解决 onTouchEvent 上奇怪的 validator 拒绝类的任何想法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9446796/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com