【发布时间】: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