Иногда происходит ConcurrentModifcationException - PullRequest
0 голосов
/ 11 октября 2018

У меня есть функция со строкой, которая предположительно предназначена для предотвращения одновременного изменения исключения. List parseObjectKeys = new ArrayList <> (parseObject.keySet ());Однако это все еще происходит время от времени

 private static void convertParseObject(ParseObject parseObject,
                                       HashMap<String, HashMap<String, WritableMap>> topLevel,
                                       ArrayList<Task<Void>> tasks) {
    if (parseObject != null) {
        String className = parseObject.getClassName();
        String id = parseObject.getObjectId();

        if (!topLevel.containsKey(className)) {
            topLevel.put(className, new HashMap<String, WritableMap>());
        }

        if (!topLevel.get(className).containsKey(id)) {
            final WritableMap flatMap = Arguments.createMap();
            flatMap.putString("class", className);
            flatMap.putString("id", id);

            if (parseObject.isDataAvailable()) {

            topLevel.get(className).put(id, flatMap);

            // This is required to prevent a ConcurrentModificationException
            List<String> parseObjectKeys = new ArrayList<>(parseObject.keySet());

            for (final String key : parseObjectKeys) {
                Object value = parseObject.get(key);

                if (value instanceof String) {
                    flatMap.putString(key, (String) value);
                } else if (value instanceof Boolean) {
                    flatMap.putBoolean(key, (Boolean) value);
                } else if (value instanceof Integer) {
                    flatMap.putInt(key, (Integer) value);
                } else if (value instanceof Double) {
                    flatMap.putDouble(key, (Double) value);
                } else if (value instanceof Date) {
                    flatMap.putString(key, Utils.toISO8601UTC((Date)value));
                }
                else {
                    if (value != null &&
                            !(value instanceof ParseACL)) {
                        Log.e(TAG, "Unknown type: " + value.getClass());
                    }
                }
            }
        }
    }
}

Ответы [ 2 ]

0 голосов
/ 11 октября 2018

HashMap не является поточно-ориентированной структурой данных, поэтому вы можете использовать ConcurrentHashMap вместо HashMap.

использовать ConcurrentHashMap<String, ConcurrentHashMap<String, WritableMap>> topLevel вместо HashMap<String, HashMap<String, WritableMap>> topLevel.

и поместите List<String> parseObjectKeys = new ArrayList<>(parseObject.keySet()); в synchronized блок.

Надеюсь, это поможет.

0 голосов
/ 11 октября 2018

Решение !!!

Добавить такой синхронизированный блок

private synchronized void convertParseObject() { }
...