SimpleDateFormat разбирает исключения и различия альтернативных методов - PullRequest
0 голосов
/ 31 октября 2018
private final static SimpleDateFormat SIMPLE_DATE_FORMAT = new SimpleDateFormat("ddMMMyy", Locale.ENGLISH);  //method 1

private static  Date getSimpleDate(String sDate) throws ParseException{
    SimpleDateFormat F = new  SimpleDateFormat("ddMMMyy", Locale.ENGLISH);
    System.out.println("pDAte:"+ F.parse(sDate).toString());
    return F.parse(sDate);
} //[method 2]


private static ThreadLocal<SimpleDateFormat> dateFormat = new ThreadLocal<SimpleDateFormat>() { 
    @Override
    protected SimpleDateFormat initialValue() {
        return new SimpleDateFormat("ddMMMyy", Locale.ENGLISH);// [method 3]
    }
};  //method3

private final static DateTimeFormatter DATE_FORMATTER = 
        new DateTimeFormatterBuilder().parseCaseInsensitive()
                                      .appendPattern("ddMMMyy")
                                      .toFormatter();  //[method 4]

Когда я анализировал дату, используя метод 1, я сталкивался с большим исключением,

java.lang.NumberFormatException: For input at 
java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)

и

java.lang.NumberFormatException: For input string: ".1818E2.1818E2" 
            at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2043)

сначала мой вопрос: это значение ".1818E2.1818E2" Я не устанавливаю это значение, но сталкиваюсь. Где прибывает ценность. Хотя я правильно устанавливаю значение даты в правильном формате, я сталкиваюсь с этой проблемой.

Но другие методы (method2, method3, method4) работают. и решил проблемы. Эти три метода являются альтернативным решением. Второй мой вопрос: что является отличительным признаком этого метода?

public Date getDscDateAsDate() throws ParseException {
    if(getDscDate()!=null) {
        return SIMPLE_DATE_FORMAT.parse(getDscDate());
    }
    return null;                
}

1 Ответ

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

SimpleDateFormat не является потокобезопасным:

Почему Java SimpleDateFormat не является поточно-ориентированным?

«Java DateFormat не является потокобезопасным», к чему это приводит?

В методе 1 вы используете экземпляр SimpleDateFormat в нескольких потоках, эти потоки могут задавать некоторые поля этого SimpleDateFormat одновременно, создавая недопустимые промежуточные результаты, такие как .1818E2.1818E2. Вы можете проверить полную трассировку стека этого исключения, чтобы получить больше информации.

В методе 2 и методе 3 каждый поток имеет свой собственный экземпляр SimpleDateFormat. Так что все в порядке.

В методе 4 вы используете DateTimeFormatter, он безопасен для потоков.

...