【问题标题】:'outofmemoryerror' in the getView() from custom BaseAdapter来自自定义 BaseAdapter 的 getView() 中的“内存不足错误”
【发布时间】:2015-04-21 09:52:47
【问题描述】:

我有一个带有网格布局的 Activity,其中显示来自 SD 文件夹的图像。当我选择一个文件夹时,所有图像都被添加到一个字符串列表中(更改文件夹时清除),并且图像构造是在 getView() 方法中,使用列表中的这些字符串。

它可以正常工作 5 或 6 次(显示来自文件夹的图像),但随后我更改了文件夹,并在自定义 BaseAdapter 的 getView() 中收到“outofmemoryerror”(请参阅​​代码行),但我没有'不明白我的泄漏问题......

每张图片大小为 30-100 kB。

这是代码:

private ArrayList<String> itemList = new ArrayList<String>();

...

public void add(String path) {
    itemList.add(path); 
}

public void clean() {
    itemList.clear();
}

public View getView(int position, View convertView, ViewGroup parent)
{   
    ImageView imageView;
    if (convertView == null)
    {
        int iImageSize = mContext.getResources().getInteger(R.integer.grid_image_size);
        int iImagePadding = mContext.getResources().getInteger(R.integer.grid_image_padding);

        imageView = new ImageView(mContext);
        imageView.setLayoutParams(new GridView.LayoutParams(iImageSize, iImageSize));
        imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
        imageView.setPadding(iImagePadding,iImagePadding,iImagePadding,iImagePadding);
    } 
    else
        imageView = (ImageView) convertView;

    String sImagePath = itemList.get(position);
    imageView.setTag(sImagePath);
    imageView.setImageURI(Uri.parse(sImagePath)); // Crash HERE

    return imageView;
}

跟踪日志:

04-21 10:10:50.697: E/art(1665): Throwing OutOfMemoryError "Failed to allocate a 1000012 byte allocation with 732188 free bytes and 715KB until OOM"

04-21 10:11:31.208:E/AndroidRuntime(1665):致命异常:主要 04-21 10:11:31.208: E/AndroidRuntime(1665): 进程: com.apps.apppictos, PID: 1665 04-21 10:11:31.208: E/AndroidRuntime(1665): java.lang.OutOfMemoryError: 无法分配 1000012 字节分配,732188 空闲字节和 715KB 直到 OOM 04-21 10:11:31.208: E/AndroidRuntime(1665): at dalvik.system.VMRuntime.newNonMovableArray(Native Method) 04-21 10:11:31.208: E/AndroidRuntime(1665): at android.graphics.BitmapFactory.nativeDecodeStream(Native Method) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.graphics.BitmapFactory.decodeStreamInternal(BitmapFactory.java:635) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:611) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:391) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:417) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.graphics.drawable.Drawable.createFromPath(Drawable.java:1143) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.ImageView.resolveUri(ImageView.java:782) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.ImageView.setImageURI(ImageView.java:429) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 com.apps.apppictos.ImageAdapter.getView(ImageAdapter.java:93) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.AbsListView.obtainView(AbsListView.java:2347) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.GridView.makeAndAddView(GridView.java:1433) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.GridView.makeRow(GridView.java:361) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.GridView.fillDown(GridView.java:302) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.GridView.fillSpecific(GridView.java:582) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.GridView.layoutChildren(GridView.java:1287) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.AbsListView.onLayout(AbsListView.java:2151) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.View.layout(View.java:15671) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewGroup.layout(ViewGroup.java:5038) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.LinearLayout.setChildFrame(LinearLayout.java:1703) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.LinearLayout.layoutVertical(LinearLayout.java:1557) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.LinearLayout.onLayout(LinearLayout.java:1466) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.View.layout(View.java:15671) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewGroup.layout(ViewGroup.java:5038) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.FrameLayout.layoutChildren(FrameLayout.java:579) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.FrameLayout.onLayout(FrameLayout.java:514) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.View.layout(View.java:15671) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewGroup.layout(ViewGroup.java:5038) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.LinearLayout.setChildFrame(LinearLayout.java:1703) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.LinearLayout.layoutVertical(LinearLayout.java:1557) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.LinearLayout.onLayout(LinearLayout.java:1466) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.View.layout(View.java:15671) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewGroup.layout(ViewGroup.java:5038) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.FrameLayout.layoutChildren(FrameLayout.java:579) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.widget.FrameLayout.onLayout(FrameLayout.java:514) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.View.layout(View.java:15671) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewGroup.layout(ViewGroup.java:5038) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewRootImpl.performLayout(ViewRootImpl.java:2086) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1843) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1061) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5885) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.Choreographer$CallbackRecord.run(Choreographer.java:767) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.Choreographer.doCallbacks(Choreographer.java:580) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.Choreographer.doFrame(Choreographer.java:550) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:753) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.os.Handler.handleCallback(Handler.java:739) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.os.Handler.dispatchMessage(Handler.java:95) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.os.Looper.loop(Looper.java:135) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 android.app.ActivityThread.main(ActivityThread.java:5257) 04-21 10:11:31.208:E/AndroidRuntime(1665):在 java.lang.reflect.Method.invoke(本机方法) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 java.lang.reflect.Method.invoke(Method.java:372) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 04-21 10:11:31.208: E/AndroidRuntime(1665): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 04-21 10:11:39.427: I/art(1665): 将目标 GC 堆从 49MB 限制到 48MB

【问题讨论】:

  • 如果你能粘贴堆栈跟踪日志会更好..
  • 图片太大,无法显示很多。先尝试缩小它们的大小。
  • 感谢您的关注,已添加痕迹。我意识到当我选择一个包含 40 张图片(8kB 到 20kB)的文件夹时会发生崩溃,是不是内存太多了??

标签: android out-of-memory baseadapter getview


【解决方案1】:

是的,使用图像可能会导致您的设备内存不足。分配的内存因设备而异。

两种方法:

  1. 使用 LruCache 类优化内存使用和缓存

    http://developer.android.com/training/displaying-bitmaps/cache-bitmap.html

  2. 使用 Picasso 一个强大的 Android 图像下载和缓存库

    http://square.github.io/picasso/

【讨论】:

  • 非常感谢 Kamal,我会尝试 LruCache,希望它有效!
【解决方案2】:

当有人像这样对 CustomView 进行膨胀时也会发生这种情况:

inflate(getContext, R.layout.my_custom_view_layout, this)

代替:

inflate(getContext, R.layout.my_custom_view_layout, null)

【讨论】:

    猜你喜欢
    • 2015-09-28
    • 2020-02-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-06-16
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多