ArrayIndexOutOfBoundsException xmlserializer

ArrayIndexOutOfBoundsException xmlserializer

我有一个使用 XMLserializer 创建 kml 文件的代码。它可以很好地创建不同的多边形,但是我在关闭 xml 时遇到错误,我真的不明白。

02-09 10:03:02.919 24712-26301/com.example.accgps W/System.err: java.lang.ArrayIndexOutOfBoundsException: length=24; index=-3
02-09 10:03:02.919 24712-26301/com.example.accgps W/System.err:     at org.kxml2.io.KXmlSerializer.endTag(KXmlSerializer.java:493)
02-09 10:03:02.919 24712-26301/com.example.accgps W/System.err:     at com.example.accgps.KMLHelper.SerialEnd(KMLHelper.java:150)
02-09 10:03:02.919 24712-26301/com.example.accgps W/System.err:     at com.example.accgps.RefreshKML.run(RefreshKML.java:283)
02-09 10:03:02.919 24712-26301/com.example.accgps W/System.err:     at java.lang.Thread.run(Thread.java:818)*

SerialEnd() 的调用是在创建多边形之后完成的,它工作正常,所以我不知道为什么它越界了:

        for (s = 0; s < PolyArray.size(); s++) {
            polygon = PolyArray.get(s);
            kH.SerialPlacePol("Tramo " + i, polygon);
            i++;
        }
        Log.i(TAG, "RefreshKML: se han creado " + (i - 1) + " tramos");
        editor.putInt("poligonos", i);
        editor.apply();
    } else {
        Toast.makeText(getApplicationContext(),"No existen datos suficientes para "+
        "generar el archivo KML",Toast.LENGTH_SHORT).show();
    }
} else {
    Log.d(TAG, "RefreshKML: No hay datos de GPS suficientes");
}

if (end) { //Solo cierra el archivo si se termina la recopilación de datos
    kH.SerialEnd();
    end = false; //En caso de que no se completó esta opción
    copyAllFiles();
}

错误是在SerialEnd()方法的第一行引起的:

public void SerialEnd () {
    try{
        serializer.endTag(null,"Document"); //THIS IS THE LINE WITH THE ERROR
        serializer.endTag(null,"kml");
        //serializer.endDocument();
        //serializer.flush();
        fileos.close();
        Log.d(TAG,"KMLHelper: SerialEnd cierra archivo KML");
    }catch(Exception e){
        Log.d(TAG,"KMLHelper: Exception occured in SerialEnd");
        e.printStackTrace();
    }
}

我尝试在其他问题中寻找答案,但没有找到合适的解决方案,可能是序列化器已关闭,但我还没有这样做

这就是我创建 XMLserializer 的方式,以防您在此处看到问题:

public KMLHelper(File file) {
    try{
        serializer.endTag(null, "Document");
        serializer.endTag(null, "kml");
        serializer.endDocument();
        serializer.flush();
        Log.d(TAG,"KMLHelper: SerialEnd cierra archivo KML");
    }catch(Exception e){
        Log.d(TAG,"KMLHelper: Exception occurred in SerialEnd");
        e.printStackTrace();
    }finally {
        try {fileos.close();} catch (IOException io) {io.printStackTrace();}
    }
}

编辑:我在 SerialEnd() 中做了一些更改,将文件的关闭放在最后并取消注释 endDocument 方法。我还控制了对创建 xml 文件的线程的访问,该线程与创建意图同步,该意图控制包含所有多边形的 XML 文件的创建。

已解决!问题是它正在创建 2 个处理同一个文件的 XMLserializer。我更改了服务调用方法的方式,现在我使用后台线程进行调用,并使用 join() 控制执行,因此一次只有 1 次执行。