我一直在从传感器读数中读取时间戳值,但由于它们以纳秒为单位提供,我想我会将它们转换为双倍并进行转换。结果数字是一个 17 位的值,加上分隔符。
尝试直接打印它会导致科学记数法,这是我不想要的,因此我使用 DecimalFormat 类将其输出到小数点后 4 位的预期值。问题是,即使调试器显示了 17 位十进制数字,即使在“doubleValue()”调用之后,输出字符串也显示了 15 位数字。
代码:
...
Double timestamp = (new Date().getTime()) + // Example: 1.3552299670232847E12
((event.timestamp - System.nanoTime()) / 1000000D);
DecimalFormat dfmt = new DecimalFormat("#.####");
switch(event.sensor.getType()){
case Sensor.TYPE_LINEAR_ACCELERATION:
case Sensor.TYPE_ACCELEROMETER:
accel = event.values.clone();
String line = "A" + LOGSEPARATOR +
dfmt.format(timestamp.doubleValue()) + // Prints: 1355229967023.28
...
我认为这可能是一个 android 精度问题,但调试器的格式化程序也显示了错误的精度。我已经在本地 java 程序中对此进行了测试,两个调用的位数相同。
这是 DecimalFormat 错误/限制吗?还是我做错了什么?