6

URLの画像を表示するためにリストビューの1つでImageLoaderを使用しています。リストをスクロールしている間、アプリは応答しませんでした。logcatをチェックして、このログレポートhttp://pastebin.com/Zfsk7r9Xを取得しました。このログには、「ターゲットGCヒープを55.234MBから48.00MBにクランプする」が表示されます。このメモリの問題を回避するにはどうすればよいですか。ImageLoaderクラスでSystem.GC()を実行しました。私が使用したdecodeFile()を以下に示します

// decodes image and scales it to reduce memory consumption
private Bitmap decodeFile(File f) {
    try {

        // decode image size
        BitmapFactory.Options o = new BitmapFactory.Options();
        o.inJustDecodeBounds = true;
        BitmapFactory.decodeStream(new FileInputStream(f), null, o);

        // Find the correct scale value. It should be the power of 2.
        final int REQUIRED_SIZE = 70;
        int width_tmp = o.outWidth, height_tmp = o.outHeight;
        int scale = 1;
        while (true) {
            if (width_tmp / 2 < REQUIRED_SIZE
                    || height_tmp / 2 < REQUIRED_SIZE)
                break;
            width_tmp /= 2;
            height_tmp /= 2;
            scale *= 2;
        }

        // decode with inSampleSize
        BitmapFactory.Options o2 = new BitmapFactory.Options();
        o2.inSampleSize = scale;
        return BitmapFactory.decodeStream(new FileInputStream(f), null, o2);
    } catch (FileNotFoundException e) {
    }
    return null;
}
4

1 に答える 1

5

「Clamp target GC heap」というメッセージは、VM が絶望的に​​なり、ヒープ割り当てが失敗し、試行後にヒープが以前の理想的な制限に戻ったときに、VM によってログに記録されます。setIdealFootprintHeapSource.cppのドキュメントから:

/*
 * Sets the maximum number of bytes that the heap source is allowed
 * to allocate from the system.  Clamps to the appropriate maximum
 * value.
 */
于 2012-12-15T06:36:00.827 に答える