我试图将长值(从1970年1月1日(即Epoch)经过的毫秒数)转换为格式为h:m:s:ms的时间.
我用作时间戳的长值,来自log4j的日志记录事件的字段时间戳.
到目前为止,我已经尝试了以下内容,但它失败了:
logEvent.timeStamp/ (1000*60*60)
TimeUnit.MILLISECONDS.toMinutes(logEvent.timeStamp)
但是我的价值不正确:
1289375173771 for logEvent.timeStamp
358159 for logEvent.timeStamp/ (1000*60*60)
21489586 for TimeUnit.MILLISECONDS.toMinutes(logEvent.timeStamp)
我该怎么做?
解决方法:
试试这个:
Date date = new Date(logEvent.timeSTamp);
DateFormat formatter = new SimpleDateFormat("HH:mm:ss.SSS");
formatter.setTimeZone(TimeZone.getTimeZone("UTC"));
String dateFormatted = formatter.format(date);
有关该类接受的其他格式字符串的说明,请参见SimpleDateFormat.
使用1200 ms的输入参见runnable example.