Cómo solucionar SIGABRT nativo con Mapsforge en Android

Estoy usando Mapsforge 0.6.1 y puedo reproducir el problema con el siguiente ejemplo reducido, que es básicamente una copia de este tutorial: https://github.com/mapsforge/mapsforge/blob/master/docs/Getting-Started -Android-App.md

He hecho algunos cambios menores para que coincidan con la nueva versión.

package org.test.mapsforgeexample; import java.io.File; import org.mapsforge.core.model.LatLong; import org.mapsforge.map.android.graphics.AndroidGraphicFactory; import org.mapsforge.map.android.util.AndroidUtil; import org.mapsforge.map.android.view.MapView; import org.mapsforge.map.layer.cache.TileCache; import org.mapsforge.map.layer.renderer.TileRendererLayer; import org.mapsforge.map.datastore.MapDataStore; import org.mapsforge.map.reader.MapFile; import org.mapsforge.map.rendertheme.InternalRenderTheme; import android.app.Activity; import android.os.Bundle; import android.os.Environment; public class MainActivity extends Activity { private static final String MAP_FILE = "berlin.map"; private MapView mapView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); AndroidGraphicFactory.createInstance(this.getApplication()); this.mapView = new MapView(this); setContentView(this.mapView); this.mapView.setClickable(true); this.mapView.getMapScaleBar().setVisible(true); this.mapView.setBuiltInZoomControls(true); this.mapView.getMapZoomControls().setZoomLevelMin((byte) 10); this.mapView.getMapZoomControls().setZoomLevelMax((byte) 20); TileCache tileCache = AndroidUtil.createTileCache(this, "mapcache", mapView.getModel().displayModel.getTileSize(), 1f, this.mapView.getModel().frameBufferModel.getOverdrawFactor()); MapDataStore mapDataStore = new MapFile(new File(Environment.getExternalStorageDirectory(), MAP_FILE)); TileRendererLayer tileRendererLayer = new TileRendererLayer(tileCache, mapDataStore, this.mapView.getModel().mapViewPosition, AndroidGraphicFactory.INSTANCE); tileRendererLayer.setXmlRenderTheme(InternalRenderTheme.OSMARENDER); this.mapView.getLayerManager().getLayers().add(tileRendererLayer); this.mapView.setCenter(new LatLong(52.517037, 13.38886)); this.mapView.setZoomLevel((byte) 12); } @Override protected void onDestroy() { this.mapView.destroyAll(); AndroidGraphicFactory.clearResourceMemoryCache(); super.onDestroy(); } } 

Para ejecutar la aplicación, tengo que descargar http://download.mapsforge.org/maps/europe/germany/berlin.map al almacenamiento externo de mi dispositivo y conceder el permiso para leerlo. La aplicación funciona bien, pero después de algunas rotaciones de pantalla, se bloquea.

 12-16 11:43:34.055 1496-1496/? A/DEBUG: *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 12-16 11:43:34.056 1496-1496/? A/DEBUG: Build fingerprint: 'google/bullhead/bullhead:7.1.1/NMF26F/3425388:user/release-keys' 12-16 11:43:34.056 1496-1496/? A/DEBUG: Revision: 'rev_1.0' 12-16 11:43:34.056 1496-1496/? A/DEBUG: ABI: 'arm64' 12-16 11:43:34.056 1496-1496/? A/DEBUG: pid: 1425, tid: 1449, name: pool-4-thread-1 >>> org.test.mapsforgeexample <<< 12-16 11:43:34.056 1496-1496/? A/DEBUG: signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr -------- 12-16 11:43:34.058 1496-1496/? A/DEBUG: Abort message: 'Error, cannot access an invalid/free'd bitmap here!' 12-16 11:43:34.058 1496-1496/? A/DEBUG: x0 0000000000000000 x1 00000000000005a9 x2 0000000000000006 x3 0000000000000008 12-16 11:43:34.058 1496-1496/? A/DEBUG: x4 0000000000000000 x5 0000000000000000 x6 00000078e82a2000 x7 0000000000000000 12-16 11:43:34.058 1496-1496/? A/DEBUG: x8 0000000000000083 x9 ffffffffffffffdf x10 0000000000000000 x11 0000000000000001 12-16 11:43:34.058 1496-1496/? A/DEBUG: x12 0000000000000018 x13 0000000000000000 x14 0000000000000000 x15 003627f486f8cd75 12-16 11:43:34.058 1496-1496/? A/DEBUG: x16 00000078e72d5ee0 x17 00000078e727faac x18 0000000007e0f81f x19 00000078c97ff4f8 12-16 11:43:34.058 1496-1496/? A/DEBUG: x20 0000000000000006 x21 00000078c97ff450 x22 000000000000000b x23 00000000138bedd0 12-16 11:43:34.058 1496-1496/? A/DEBUG: x24 00000000138c1300 x25 00000078d79047e0 x26 00000078c8e4c720 x27 0000000013b99b98 12-16 11:43:34.058 1496-1496/? A/DEBUG: x28 00000000138c12f0 x29 00000078c97fe320 x30 00000078e727ced8 12-16 11:43:34.058 1496-1496/? A/DEBUG: sp 00000078c97fe300 pc 00000078e727fab4 pstate 0000000060000000 12-16 11:43:34.549 1496-1496/? A/DEBUG: backtrace: 12-16 11:43:34.549 1496-1496/? A/DEBUG: #00 pc 000000000006bab4 /system/lib64/libc.so (tgkill+8) 12-16 11:43:34.549 1496-1496/? A/DEBUG: #01 pc 0000000000068ed4 /system/lib64/libc.so (pthread_kill+64) 12-16 11:43:34.549 1496-1496/? A/DEBUG: #02 pc 0000000000023f58 /system/lib64/libc.so (raise+24) 12-16 11:43:34.549 1496-1496/? A/DEBUG: #03 pc 000000000001c810 /system/lib64/libc.so (abort+52) 12-16 11:43:34.549 1496-1496/? A/DEBUG: #04 pc 0000000000010c24 /system/lib64/libcutils.so (__android_log_assert+224) 12-16 11:43:34.549 1496-1496/? A/DEBUG: #05 pc 00000000001073e4 /system/lib64/libandroid_runtime.so (_ZNK7android6Bitmap11assertValidEv+40) 12-16 11:43:34.549 1496-1496/? A/DEBUG: #06 pc 00000000001074c8 /system/lib64/libandroid_runtime.so (_ZN7android6Bitmap11getSkBitmapEP8SkBitmap+20) 12-16 11:43:34.550 1496-1496/? A/DEBUG: #07 pc 000000000010359c /system/lib64/libandroid_runtime.so 12-16 11:43:34.550 1496-1496/? A/DEBUG: #08 pc 0000000001a9a3a0 /system/framework/arm64/boot-framework.oat (offset 0x1686000) (android.graphics.Canvas.nativeDrawBitmapMatrix+172) 12-16 11:43:34.550 1496-1496/? A/DEBUG: #09 pc 0000000001a9e9b8 /system/framework/arm64/boot-framework.oat (offset 0x1686000) (android.graphics.Canvas.drawBitmap+148) 12-16 11:43:34.550 1496-1496/? A/DEBUG: #10 pc 000000000000135c /data/data/org.test.mapsforgeexample/cache/slice-mapsforge-map-android-0.6.0_24fb6ab0ab8de752356b68dd9111194aa0b25568-classes.dex (offset 0x1c000) 

El problema es, cuando gira la pantalla, onDestroy() se llama, seguido de onCreate() . Puedo reproducir esto con aplicaciones más complejas con múltiples actividades cambiando entre la actividad del mapa y otra diferente. A veces, los recursos free'd en AndroidGraphicFactory.clearResourceMemoryCache() ( onDestroy() ) no pueden reutilizarse inmediatamente para volver a dibujar el mapa en onCreate() .

Una posible solución es eliminar la llamada AndroidGraphicFactory.clearResourceMemoryCache() de onDestroy() . Como me di cuenta, esto no tiene ningún sentido en todos en Mapsforge 0.6.0, ya que se ha llamado en destroyAll() también, la eliminación de la llamada o bien habría causado una fuga de memoria masiva.

En la versión actual 0.6.1, usando al siguiente método, el error no ocurre, porque AndroidGraphicFactory.clearResourceMemoryCache() nunca se llama.

 @Override protected void onDestroy() { this.mapView.destroyAll(); super.onDestroy(); } 

Aunque mi aplicación parece funcionar bien, todavía no estoy convencido, porque creo que todavía hay una fuga de recursos. ¿Es esto cierto o la solución está bien? ¿Hay un mejor, tal vez un punto diferente en el código para abrir / cerrar AndroidGraphicFactory? Cualquier sugerencia será muy apreciada.

Estoy probando con un Nexus 5X y Android 7.1.1, pero puedo reproducir este problema en varios dispositivos y versiones del sistema operativo.

Por favor, intente esto si puede resolver su problema: –

  @Override protected void onDestroy() { super.onDestroy(); if (isFinishing()) { // do stuff } else { //It's an orientation change. } } 
  • Galería circular de Android o lista con zoom en y fuera de la opción
  • ¿Por qué funciona algún código de Android en el nivel de API anterior de lo que debería?
  • El niño especificado ya tiene un padre. Debe llamar a removeView () en el primer padre del niño (Android)
  • El servicio de facturación no está disponible en el dispositivo. (Respuesta: 3: Facturación no disponible)
  • Carga de un archivo a través de SSL con Client Side Certificate y HttpsURLConnection de Android
  • Error de generación de Gradle: no se puede acceder al archivo de clase ITest bad: Método por defecto de ITest.class encontrado en la versión 50.0 classfile
  • ¿Cómo separar fragmentos a diferentes archivos en android studio?
  • Anónimo Subir objeto de archivo a la API Imgur (JSON) da error de autenticación 401
  • Android: ¿Cómo cargar dinámicamente las clases de un archivo JAR?
  • Sprite Rotación alrededor de un punto Andengine / Java
  • Error de logcat de Android: ZipFileCache: init falló cuando archivo zip abierto - específico del dispositivo?
  • FlipAndroid es un fan de Google para Android, Todo sobre Android Phones, Android Wear, Android Dev y Aplicaciones para Android Aplicaciones.