ListView
содержит довольно много элементов (20 или более), и каждый из них является ImageView
с растровым источником. Эти растровые изображения не сжаты и имеют размер около 640x480. Когда ListView
просто загружен, он занимает немного памяти, но если я прокручу его, тогда может произойти ошибка "Memory exceed VM budjet"
. Когда я заменяю фрагмент другим фрагментом, ListView
все еще висит в памяти. Как я могу очистить кеш ram/ListView?
Обновить :
Я использую SimpleCursorAdapter
с ViewBinder
:
SimpleCursorAdapter.ViewBinder viewBinder = new SimpleCursorAdapter.ViewBinder() {
public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
if (columnIndex == 0) {
TextView tv1 = (TextView) view;
if (cursor.getInt(4) == 0)
tv1.setTextColor(Color.GRAY);
else
tv1.setTextColor(Color.parseColor("#191919"));
tv1.setText(cursor.getString(columnIndex));
}
if (columnIndex == 3) {
TextView tv1 = (TextView) view;
tv1.setText(cursor.getString(columnIndex));
}
if (columnIndex == 2) {
final ImageView image = (ImageView) view;
Bitmap cachedImage = null;
try {
cachedImage = imageThreadLoader.loadImage(cursor.getString(columnIndex), new ImageThreadLoader.ImageLoadedListener() {
public void imageLoaded(Bitmap imageBitmap) {
image.setImageBitmap((Bitmap) new SoftReference(imageBitmap).get());
}
});
} catch (MalformedURLException mue) {
Log.e("Feeds fragment", "Can't load image");
}
if (cachedImage != null) {
image.setImageBitmap(cachedImage);
} else image.setImageDrawable(getResources().getDrawable(R.drawable.icon));
}
Загрузка изображений осуществляется в отдельном потоке.
Я рекомендую вам посмотреть презентацию Google IO о ListViews. Он содержит методы экономии памяти, и это помогло мне понять логику ListViews.
создайте список, как это, сделайте свой пользовательский адаптер и установите его в listview
public class InteractiveArrayAdapter extends ArrayAdapter<Model> {
private final List<Model> list;
private final Activity context;
public InteractiveArrayAdapter(Activity context, List<Model> list) {
super(context, R.layout.main, list);
this.context = context;
this.list = list;
}
static class ViewHolder {
protected TextView text;
protected CheckBox checkbox;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = null;
if (convertView == null) {
LayoutInflater inflator = context.getLayoutInflater();
view = inflator.inflate(R.layout.main, null);
final ViewHolder viewHolder = new ViewHolder();
viewHolder.text = (TextView) view.findViewById(R.id.listitem_text);
viewHolder.checkbox = (CheckBox) view.findViewById(R.id.checkBox1);
viewHolder.checkbox
.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
public void onCheckedChanged(CompoundButton buttonView,
boolean isChecked) {
Model element = (Model) viewHolder.checkbox
.getTag();
element.setSelected(buttonView.isChecked());
}
});
view.setTag(viewHolder);
viewHolder.checkbox.setTag(list.get(position));
} else {
view = convertView;
((ViewHolder) view.getTag()).checkbox.setTag(list.get(position));
}
ViewHolder holder = (ViewHolder) view.getTag();
holder.text.setText(list.get(position).getName());
holder.checkbox.setChecked(list.get(position).isSelected());
return view;
}
}
попробуйте этот путь, и ваше ненужное представление будет переработано, а исключение будет быстрее и надеюсь, что вы избавитесь от ошибки