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.
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. –
sembra che più thread stiano correndo per usare la stessa istanza e rovinare il suo stato interno, è così? –
@JonSkeet Aggiornerò il post in un secondo mostrando i dati di esempio. – Hele