如何修复 android 中的 InvocationTargetException、OutOfMemoryError 和 IllegalStateException?
How can i fix InvocationTargetException, OutOfMemoryError and IllegalStateException in android?
我正在调用此函数为 ImageView 对象设置背景图像 "smileysImg" 并播放动画 "smileyFadeoutAnim"。这是代码:
public void showSmileyImage(){
if(smileyNum > 5)
smileyNum = 1;
else smileyNum++;
switch (smileyNum){
case 1: smileysImg.setBackgroundResource(R.drawable.smiley_1); break;
case 2: smileysImg.setBackgroundResource(R.drawable.smiley_2); break;
case 3: smileysImg.setBackgroundResource(R.drawable.smiley_3); break;
case 4: smileysImg.setBackgroundResource(R.drawable.smiley_4); break;
case 5: smileysImg.setBackgroundResource(R.drawable.smiley_5); break;
default: smileysImg.setBackgroundResource(R.drawable.smiley_5);
}
smileysImg.setVisibility(View.VISIBLE);
smileyFadeoutAnim.setAnimationListener(new Animation.AnimationListener()
{
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
smileysImg.setVisibility(View.GONE);
smileysImg.clearAnimation();
smileysImg.setBackgroundResource(0);
}
@Override
public void onAnimationRepeat(Animation animation) {
}
});
smileysImg.startAnimation(smileyFadeoutAnim);
}
有时能正常工作,有时会崩溃并显示此错误日志
FATAL EXCEPTION: main
Process: com.testaday.tad1stgrademathpractice, PID: 32399
java.lang.IllegalStateException: Could not execute method of the activity
at android.view.View.onClick(View.java:3823)
at android.view.View.performClick(View.java:4438)
at android.view.View$PerformClick.run(View.java:18422)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3818)
at android.view.View.performClick(View.java:4438)
at android.view.View$PerformClick.run(View.java:18422)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.OutOfMemoryError
at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:587)
at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:422)
at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:840)
at android.content.res.Resources.loadDrawable(Resources.java:2115)
at android.content.res.Resources.getDrawable(Resources.java:700)
at android.view.View.setBackgroundResource(View.java:15303)
at com.testaday.tad1stgrademathpractice.ExamView.showSmileyImage(ExamView.java:836)
at com.testaday.tad1stgrademathpractice.ExamView.onClick_submit(ExamView.java:750)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3818)
at android.view.View.performClick(View.java:4438)
at android.view.View$PerformClick.run(View.java:18422)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
如何解决这个问题。
我改了下面的代码
case 1: smileysImg.setBackgroundResource(R.drawable.smiley_1); break;
到
smileysImg.setImageDrawable(ResourcesCompat.getDrawable(getResources(), R.drawable.smiley_1, null))
我也这样做了
android:largeHeap="true"
未能解决问题。应用程序仍然崩溃,但比以前花费了更多时间。
不正确缩放图像会导致 OutofMemoryError 但我的图像很小,所以我认为没有必要缩小它们。
经过大量搜索,我发现 from this answer 在调用我的 showSmileyImage()
之前调用 System.gc();
是个好主意。它解决了这个问题。
但我也发现这个 answer 与第一个答案相矛盾 "probably",但仍然调用 gc 解决了问题。
我正在调用此函数为 ImageView 对象设置背景图像 "smileysImg" 并播放动画 "smileyFadeoutAnim"。这是代码:
public void showSmileyImage(){
if(smileyNum > 5)
smileyNum = 1;
else smileyNum++;
switch (smileyNum){
case 1: smileysImg.setBackgroundResource(R.drawable.smiley_1); break;
case 2: smileysImg.setBackgroundResource(R.drawable.smiley_2); break;
case 3: smileysImg.setBackgroundResource(R.drawable.smiley_3); break;
case 4: smileysImg.setBackgroundResource(R.drawable.smiley_4); break;
case 5: smileysImg.setBackgroundResource(R.drawable.smiley_5); break;
default: smileysImg.setBackgroundResource(R.drawable.smiley_5);
}
smileysImg.setVisibility(View.VISIBLE);
smileyFadeoutAnim.setAnimationListener(new Animation.AnimationListener()
{
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
smileysImg.setVisibility(View.GONE);
smileysImg.clearAnimation();
smileysImg.setBackgroundResource(0);
}
@Override
public void onAnimationRepeat(Animation animation) {
}
});
smileysImg.startAnimation(smileyFadeoutAnim);
}
有时能正常工作,有时会崩溃并显示此错误日志
FATAL EXCEPTION: main
Process: com.testaday.tad1stgrademathpractice, PID: 32399
java.lang.IllegalStateException: Could not execute method of the activity
at android.view.View.onClick(View.java:3823)
at android.view.View.performClick(View.java:4438)
at android.view.View$PerformClick.run(View.java:18422)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3818)
at android.view.View.performClick(View.java:4438)
at android.view.View$PerformClick.run(View.java:18422)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.OutOfMemoryError
at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:587)
at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:422)
at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:840)
at android.content.res.Resources.loadDrawable(Resources.java:2115)
at android.content.res.Resources.getDrawable(Resources.java:700)
at android.view.View.setBackgroundResource(View.java:15303)
at com.testaday.tad1stgrademathpractice.ExamView.showSmileyImage(ExamView.java:836)
at com.testaday.tad1stgrademathpractice.ExamView.onClick_submit(ExamView.java:750)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3818)
at android.view.View.performClick(View.java:4438)
at android.view.View$PerformClick.run(View.java:18422)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
如何解决这个问题。
我改了下面的代码
case 1: smileysImg.setBackgroundResource(R.drawable.smiley_1); break;
到
smileysImg.setImageDrawable(ResourcesCompat.getDrawable(getResources(), R.drawable.smiley_1, null))
我也这样做了
android:largeHeap="true"
未能解决问题。应用程序仍然崩溃,但比以前花费了更多时间。 不正确缩放图像会导致 OutofMemoryError 但我的图像很小,所以我认为没有必要缩小它们。
经过大量搜索,我发现 from this answer 在调用我的 showSmileyImage()
之前调用 System.gc();
是个好主意。它解决了这个问题。
但我也发现这个 answer 与第一个答案相矛盾 "probably",但仍然调用 gc 解决了问题。