Android でソフト参照を使用しているときに奇妙な問題が発生しました。ビットマップ キャッシュ用のクラスを実装しました。ソース コードは次のとおりです。
public class ImageCache
{
private static HashMap<String, SoftReference<Bitmap>> mCache = new HashMap<String, SoftReference<Bitmap>>();
private static final String TAG = "ImageCache";
public static Bitmap getBitmap(String url)
{
Bitmap bitmap = null;
if (mCache.containsKey(url))
{
Log.d(TAG, "use cache: " + url);
bitmap = mCache.get(url).get();
if (bitmap != null)
{
return bitmap;
}
else
{
Log.w(TAG, "#######################soft ref was collected!!!");
}
}
bitmap = BitmapFactory.decodeFile(url);
if (bitmap == null)
{
Log.e(TAG, "#####jpg not found");
return null;
}
bitmap = Bitmap.createScaledBitmap(bitmap, 320, 240, false);
synchronized (mCache) {
mCache.put(url, new SoftReference<Bitmap>(bitmap));
}
return bitmap;
}
}
しかし、logcat を調べてみると、ソフト リファレンスが頻繁に収集されていることがわかりました。ログは次のとおりです。
#######################soft ref was collected!!!
私の知る限り、Java ヒープが限界まで大きくなり、新しいメモリ割り当て用のスペースがない場合にのみ、GC によってソフト参照が収集されます。
しかし、Android のソフト参照が期待どおりに動作しないのはなぜですか?