Der Code wie die in onResume einer Aktivität finden:Android aufblasen verursacht java.lang.OutOfMemoryError occaionally
for (int i = 0; i < 4; i++) {
LayoutInflater.from(this).inflate(R.layout.image_view, gridLayout);
...
}
Die Komponente der Layout-image_view dem Absturz im Zusammenhang ist folgende:
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center"
android:layout_margin="0dip"
android:padding="0dip"
android:scaleType="centerCrop"
android:src="@drawable/ic_launcher_background" />
Die Auflösung der Image-Datei ic_launcher_background.png beträgt 399x399.
Die gelegentliche Crash-Bericht ist die folgende:
java.lang.OutOfMemoryError
at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:677)
at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:507)
at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:872)
at android.content.res.Resources.loadDrawable(Resources.java:3022)
at android.content.res.TypedArray.getDrawable(TypedArray.java:602)
at android.widget.ImageView.<init>(ImageView.java:133)
at android.support.v7.widget.ar.<init>(SourceFile:58)
at android.support.v7.widget.ar.<init>(SourceFile:54)
at android.support.v7.a.au.a(SourceFile:95)
at android.support.v7.a.af.c(SourceFile:938)
at android.support.v7.a.af.a(SourceFile:992)
at android.support.v4.g.ad.onCreateView(SourceFile:44)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:690)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:761)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:769)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:769)
at android.view.LayoutInflater.inflate(LayoutInflater.java:498)
at android.view.LayoutInflater.inflate(LayoutInflater.java:398)
at android.view.LayoutInflater.inflate(LayoutInflater.java:354)
at net.mydomain.app.fooActivity.onResume(SourceFile:609)
at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1210)
at android.app.Activity.performResume(Activity.java:5468)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2873)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2912)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2345)
at android.app.ActivityThread.access$800(ActivityThread.java:157)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1247)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:157)
at android.app.ActivityThread.main(ActivityThread.java:5293)
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:1265)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)
at dalvik.system.NativeStart.main(Native Method)
Ich möchte betonen, dass dies geschieht selten, aber es kann nicht von der catch-Block des Codes aufgefangen werden, so stürzt die App.
Könnte irgendjemand etwas Licht darauf werfen?
Haben Sie jemals eine Lösung gefunden? – andygeers
Nein. Dies selten nur gelegentlich. Es ist für eine Weile nicht passiert. – Hong
In meiner App habe ich es aufgespürt, weil mir eine hdpi-Version eines bestimmten Zeichens fehlte, also musste ich eine mdpi-Version im laufenden Betrieb ändern – andygeers