У меня есть ListActivity
, и в нем я установил элементы списка с классом, который расширяет SimpleCursorAdapter
.Я переопределяю bindView
, чтобы установить Views
.У меня есть TextViews
и ImageViews
.Вот как я устанавливаю элементы списка в моем адаптере курсора:
String variableName = "drawable/q" + num + "_200px";
int imageResource = context.getResources().getIdentifier(variableName, "drawable", context.getPackageName());
if (imageResource != 0 ) {
// The drawable exists
Bitmap b = BitmapFactory.decodeResource(context.getResources(), imageResource);
width = b.getWidth();
height = b.getHeight();
imageView.getLayoutParams().width = (int) (width);
imageView.getLayoutParams().height = (int) (height);
imageView.setImageResource(imageResource);
} else {
imageView.setImageResource(R.drawable.25trans_200px);
}
Проблема, с которой я сталкиваюсь, заключается в том, что всякий раз, когда я обновляю свой список с помощью setListAdapter
, я получаю большое количество мусора:
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 125K, 51% free 2710K/5447K, external 2022K/2137K, paused 75ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 30K, 51% free 2701K/5447K, external 2669K/2972K, paused 64ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 23K, 51% free 2713K/5447K, external 3479K/3579K, paused 53ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 22K, 51% free 2706K/5447K, external 3303K/3352K, paused 64ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 21K, 51% free 2722K/5447K, external 3569K/3685K, paused 102ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 23K, 50% free 2755K/5447K, external 3499K/3605K, paused 65ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 23K, 50% free 2771K/5447K, external 4213K/4488K, paused 53ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 18K, 49% free 2796K/5447K, external 5057K/5343K, paused 75ms
D/dalvikvm(18637): GC_EXTERNAL_ALLOC freed 28K, 49% free 2803K/5447K, external 5944K/5976K, paused 53ms
D/dalvikvm( 435): GC_EXPLICIT freed 6K, 54% free 2544K/5511K, external 1625K/2137K, paused 50ms
D/dalvikvm( 165): GC_EXPLICIT freed 85K, 52% free 2946K/6087K, external 4838K/5980K, paused 111ms
D/dalvikvm( 448): GC_EXPLICIT freed 1K, 54% free 2540K/5511K, external 1625K/2137K, paused 50ms
D/dalvikvm( 294): GC_EXPLICIT freed 8K, 55% free 2598K/5703K, external 1625K/2137K, paused 64ms
Что я могу сделать, чтобы избежать этого?Это заставляет мой интерфейс быть вялым, и когда я прокручиваю, тоже.