2014-12-28 11 views
5

Durante l'analisi di un gran numero di date in Java, ho avuto occasione di ottenere questo strano bug:Strano Data di errore di analisi in Java

java.lang.NumberFormatException: For input string: ".201144E4.201144E4" 
    at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1250) 
    at java.lang.Double.parseDouble(Double.java:540) 
    at java.text.DigitList.getDouble(DigitList.java:168) 
    at java.text.DecimalFormat.parse(DecimalFormat.java:1321) 
    at java.text.SimpleDateFormat.subParse(SimpleDateFormat.java:1793) 
    at java.text.SimpleDateFormat.parse(SimpleDateFormat.java:1455) 
    at java.text.DateFormat.parse(DateFormat.java:355) 
    at gameloop.tf2tradebot.user.UserManager.getUser(UserManager.java:102) 
    at gameloop.tradebot2.bot.weaponbot1.Weaponbot1.onMessageReceived(Weaponbot1.java:269) 
    at gameloop.api.steam.chat.ChatEvent.run(ChatEvent.java:49) 
    at java.lang.Thread.run(Thread.java:745) 

I questo caso, la data era

2014-12-13 06:56:27 

Il formato della data era

private static final DateFormat STANDARD_DATE_FORMAT = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.ENGLISH); 

Il mio codice:

Date firstSeenDate = null; 
try 
{ 
    firstSeenDate = STANDARD_DATE_FORMAT.parse(firstSeen); 
} 
catch(Exception pe) 
{ 
    pe.printStackTrace(); 
    logger.outputError(4001, "Error parsing first seen date. Shutting down..."); 
    logger.outputError(4001, "First seen date : \'" + firstSeen + "\'"); 
    CH405BotServer.shutdown(logger.getCallerName(), "an error in parsing first seen date"); 
} 
user.setFirstSeen(firstSeenDate); 

dati Fonte:

isadmin = false 
firstseen = 2014-12-13 06:56:27 
lastseen = 2014-12-13 06:56:27 
numtrades = 0 

EDIT: La stringa nel log degli errori sembra perfettamente bene:

(ERROR 4001) Error parsing first seen date. Shutting down... 
(ERROR 4001) Last seen date : '2014-12-13 06:56:27' 

Ho bisogno di aiuto su come risolvere questo problema.

+4

Sembra che stai ricevendo dati errati - stai cercando di analizzare un valore di "" .201144E45.2011 44E4 "' che chiaramente non è una data/ora nel formato 'aaaa-MM-gg HH: mm: ss'. Sfortunatamente non ci hai detto nulla su da dove provengono i dati. –

+4

sembra che più thread stiano correndo per usare la stessa istanza e rovinare il suo stato interno, è così? –

+0

@JonSkeet Aggiornerò il post in un secondo mostrando i dati di esempio. – Hele

risposta

4

Ho il sospetto che è causato dalla condizione di competizione, SimpleDateFormat è non thread-safe e se più thread tenta di analizzare Data da stringa a data utilizzando lo stesso isntance che poteva rovinare stato interno di tale istanza

I suggerirei utilizzare la variabile locale (attenzione: è costoso creare questa istanza), quindi se pensi che sia troppo frequente, puoi usare FastDateFormat (implementazione thread-safe di) o come @Ray suggested switch to Java8

+0

plus1 Grazie per quello, ho avuto la brutta sensazione che questo errore fosse dovuto a un problema più grande. – Hele

+0

Ciao, è stata una domanda interessante –