ときどきアプリがクラッシュし、ログに次のように表示されます。
@@@ ABORTING: INVALID HEAP ADDRESS IN dlfree
Fatal signal 11 (SIGSEGV) at 0xdeadbaad (code=1)
時々、code=2
しかし常に。Fatal signal 11
invalid heap address
これが何を意味し、どのように修正するかを調査してみました。このスレッドが最も役に立ちました。しかし、私はまだ解決策がありません。
AsyncTasks
いくつかのイメージをダウンロードするためにいくつかを実行すると、エラーが発生します。
これが私のメインですAsyncTask
public class FetchArtistImages extends AsyncTask<Void, Integer, String[]> implements Constants {
private final WeakReference<Context> contextReference;
public FetchArtistImages(Context context) {
contextReference = new WeakReference<Context>(context);
}
@Override
protected String[] doInBackground(Void... params) {
String[] projection = new String[] {
Audio.Artists._ID, Audio.Artists.ARTIST
};
String sortOrder = Audio.Artists.DEFAULT_SORT_ORDER;
Uri uri = Audio.Artists.EXTERNAL_CONTENT_URI;
Cursor c = contextReference.get().getContentResolver()
.query(uri, projection, null, null, sortOrder);
ArrayList<String> artistIds = new ArrayList<String>();
if (c != null) {
int count = c.getCount();
if (count > 0) {
final int ARTIST_IDX = c.getColumnIndex(Audio.Artists.ARTIST);
for (int i = 0; i < count; i++) {
c.moveToPosition(i);
artistIds.add(c.getString(ARTIST_IDX));
}
}
c.close();
c = null;
}
return artistIds.toArray(new String[artistIds.size()]);
}
@Override
protected void onPostExecute(String[] result) {
for (int i = 0; i < result.length; i++) {
new LastfmGetArtistImages(contextReference.get()).executeOnExecutor(
AsyncTask.THREAD_POOL_EXECUTOR, result[i]);
}
super.onPostExecute(result);
}
これがどうなっているのかを調べてみましたが、修正に関してはまだ迷っています。誰かが何らかの洞察を持っているなら、私はそれを見ていただければ幸いです。毎回エラーがスローされるわけではありませんがexecute
、AsyncTasks
これが発生している理由を特定するのに役立つパターンがあまり見つかりません。SO に関する他のスレッドがいくつかありますがfatal signal 11
、私の場合はあまり役に立ちません。