Неожиданные побочные эффекты при разборе дат в Android

В различных проектах Android я использую следующую статическую функцию для разбора дат, например: 1900-12-31, Конечно, эта функция должна быть детерминированной - но, оказывается, это не так. Зачем?

Обычно он разбирает дату 2010-10-30например, правильно Date экземпляр, содержащий это значение. Но я заметил, что когда у меня есть IntentService Работая в то же время и анализируя некоторые даты, эта функция анализирует ту же дату, что и выше, 1983-01-20, который является одной из дат, проанализированных в IntentService, Как это может случиться?

public static Date dateFromString(String dateStr) {
    SimpleDateFormat mDateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.getDefault());
    SimpleDateFormat mDateTimeFormat = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ", Locale.getDefault());
    Date dateOut = null;
    try {
        if (dateStr != null) {
            if (dateStr.length() == 7) {
                if (dateStr.startsWith("--")) {
                    dateStr = "0000"+dateStr.substring(1);
                }
            }
            else if (dateStr.length() == 6) {
                if (dateStr.startsWith("-")) {
                    dateStr = "0000"+dateStr;
                }
            }
            else if (dateStr.length() == 5) {
                dateStr = "0000-"+dateStr;
            }
            else if (dateStr.matches("[0-9]{2}\\.[0-9]{2}\\.[0-9]{4}")) {
                dateStr = dateStr.substring(6, 10)+"-"+dateStr.substring(3, 5)+"-"+dateStr.substring(0, 2);
            }
            else if (dateStr.matches("[0-9]{2}\\/[0-9]{2}\\/[0-9]{4}")) {
                dateStr = dateStr.substring(6, 10)+"-"+dateStr.substring(3, 5)+"-"+dateStr.substring(0, 2);
            }
            else if (dateStr.matches("[0-9]{8}")) {
                dateStr = dateStr.substring(0, 4)+"-"+dateStr.substring(4, 6)+"-"+dateStr.substring(6, 8);
            }
            if (dateStr.length() >= 20) {
                String dateTimeStr = dateStr.trim();
                if (dateTimeStr.endsWith("Z")) {
                    dateTimeStr = dateStr.substring(0, dateTimeStr.length()-1)+"+0000";
                }
                if (dateStr.charAt(10) == ' ') {
                    dateTimeStr = dateStr.substring(0, 10)+"T"+dateStr.substring(11);
                }
                try {
                    dateOut = mDateTimeFormat.parse(dateTimeStr);
                }
                catch (Exception e2) {
                    dateOut = mDateFormat.parse(dateStr);
                }
            }
            else {
                dateOut = mDateFormat.parse(dateStr);
            }
        }
    }
    catch (Exception e) {
        dateOut = null;
    }
    return dateOut;
}

Редактировать: я делаю анализ в моем Activity"s onCreate() где я начинаю AsyncTask это делает работу. в Activity"s onStop()запускается фоновая служба, которая выполняет ту же работу. Когда я закрываю приложение (onStop()) и быстро перезапускаю его (onCreate()), кажется, что оба работают одновременно, и возникает ошибка.

1 ответ

Решение

Документация SimpleDateFormat говорит:

SimpleDateFormat не является потокобезопасным. Пользователи должны создать отдельный экземпляр для каждого потока.

Вот и ты. Просто создайте SimpleDateFormat Объект отдельно в каждом потоке и передать его в метод.

Другие вопросы по тегам