请帮忙解决这些异常,android?

时间:2013-07-11 06:08:31

标签: android out-of-memory

这是我的应用程序的logcat

  07-11 11:31:25.269: D/-heap(6666): GC_FOR_ALLOC freed 1256K, 13% free 28316K/32227K, paused 34ms
  07-11 11:31:25.309: D/-heap(6666): GC_BEFORE_OOM freed 414K, 14% free 27901K/32227K, paused 42ms
  07-11 11:31:25.309: E/dalvikvm-heap(6666): Out of memory on a 20155408-byte allocation.
  07-11 11:31:25.309: I/dalvikvm(6666): "main" prio=5 tid=1 RUNNABLE
  07-11 11:31:25.309: I/dalvikvm(6666):   | group="main" sCount=0 dsCount=0 obj=0x40b01c58 self=0x1640e80
  07-11 11:31:25.309: I/dalvikvm(6666):   | sysTid=6666 nice=0 sched=0/0 cgrp=default handle=1074922856
  07-11 11:31:25.319: I/dalvikvm(6666):   | schedstat=( 0 0 0 ) utm=351 stm=36 core=0
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.graphics.BitmapFactory.nativeDecodeStream(Native Method)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:500)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:306)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:331)
  07-11 11:31:25.319: I/dalvikvm(6666):   at com.callplanets.chat.ui.Talk$DiscussArrayAdapter.getView(Talk.java:939)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.AbsListView.obtainView(AbsListView.java:2045)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.ListView.makeAndAddView(ListView.java:1772)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.ListView.fillUp(ListView.java:705)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.ListView.correctTooHigh(ListView.java:1395)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.ListView.fillSpecific(ListView.java:1333)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.ListView.layoutChildren(ListView.java:1615)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.AbsListView.onLayout(AbsListView.java:1875)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.RelativeLayout.onLayout(RelativeLayout.java:930)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.FrameLayout.onLayout(FrameLayout.java:444)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1653)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1511)
  07-11 11:31:25.319: I/dalvikvm(6666):   at android.widget.LinearLayout.onLayout(LinearLayout.java:1416)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.widget.FrameLayout.onLayout(FrameLayout.java:444)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1490)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2455)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.os.Handler.dispatchMessage(Handler.java:99)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.os.Looper.loop(Looper.java:137)
  07-11 11:31:25.329: I/dalvikvm(6666):   at android.app.ActivityThread.main(ActivityThread.java:4424)
  07-11 11:31:25.329: I/dalvikvm(6666):   at java.lang.reflect.Method.invokeNative(Native Method)
  07-11 11:31:25.329: I/dalvikvm(6666):   at java.lang.reflect.Method.invoke(Method.java:511)
  07-11 11:31:25.329: I/dalvikvm(6666):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:817)
  07-11 11:31:25.329: I/dalvikvm(6666):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:584)
  07-11 11:31:25.329: I/dalvikvm(6666):   at dalvik.system.NativeStart.main(Native Method)
  07-11 11:31:26.399: E/dalvikvm(6666): can't open /data/misc/hprof_oom_dump.hprof: Permission denied
  07-11 11:31:26.419: D/-heap(6666): Dump of hprof is not done
  07-11 11:31:26.419: D/skia(6666): --- decoder->decode returned false
  07-11 11:31:26.419: W/dalvikvm(6666): threadid=1: thread exiting with uncaught exception (group=0x40b009f0)
  07-11 11:31:26.429: E/AndroidRuntime(6666): FATAL EXCEPTION: main
  07-11 11:31:26.429: E/AndroidRuntime(6666): java.lang.OutOfMemoryError
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.graphics.BitmapFactory.nativeDecodeStream(Native Method)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:500)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:306)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:331)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at com.callplanets.chat.ui.Talk$DiscussArrayAdapter.getView(Talk.java:939)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.AbsListView.obtainView(AbsListView.java:2045)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.ListView.makeAndAddView(ListView.java:1772)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.ListView.fillUp(ListView.java:705)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.ListView.correctTooHigh(ListView.java:1395)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.ListView.fillSpecific(ListView.java:1333)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.ListView.layoutChildren(ListView.java:1615)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.AbsListView.onLayout(AbsListView.java:1875)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.RelativeLayout.onLayout(RelativeLayout.java:930)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.FrameLayout.onLayout(FrameLayout.java:444)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1653)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1511)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.LinearLayout.onLayout(LinearLayout.java:1416)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.widget.FrameLayout.onLayout(FrameLayout.java:444)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.View.layout(View.java:11390)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.ViewGroup.layout(ViewGroup.java:4332)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1490)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2455)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.os.Handler.dispatchMessage(Handler.java:99)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.os.Looper.loop(Looper.java:137)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at android.app.ActivityThread.main(ActivityThread.java:4424)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at java.lang.reflect.Method.invokeNative(Native Method)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at java.lang.reflect.Method.invoke(Method.java:511)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:817)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:584)
  07-11 11:31:26.429: E/AndroidRuntime(6666):   at dalvik.system.NativeStart.main(Native Method)

这些是主要的例外情况: 07-11 11:31:25.309:E / dalvikvm-heap(6666):20155408字节分配内存不足。 07-11 11:31:26.399:E / dalvikvm(6666):无法打开/data/misc/hprof_oom_dump.hprof:权限被拒绝

我如何解决这些问题? 请告诉....

我有一项活动,我在其中显示从图库中挑选的图像的缩略图。 点击缩略图后,将用户带到另一个活动并显示常规尺寸。

在第二个活动的背面发生此异常。

1 个答案:

答案 0 :(得分:1)

通过缩小/缩放图像的大小,您可以摆脱内存不足异常,试试这个

BitmapFactory.Options options = new BitmapFactory.Options(); options.inSampleSize = 8; Bitmap receipt = BitmapFactory.decodeFile(photo.toString(),options); //From File You can customise on your needs.