我正在尝试将一个长值(从1970年1月1日经过的毫秒数,即Epoch)转换为格式时间h:m:s:ms。
h:m:s:ms
我用作时间戳记的长值timestamp,是从log4j的日志记录事件字段获得的。
timestamp
到目前为止,我已经尝试了以下操作,但失败了:
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输入的可运行示例。