When I read the mtime
of a file from Java using Files.getLastModifiedTime
, the return value is truncated to whole seconds. I know this works on other systems to get mtimes with millisecond resolution, so what could be different about mine?
Here is a complete standalone test which compiles and runs:
import java.nio.file.attribute.FileTime;
import java.nio.file.Files;
import java.nio.file.Paths;
public class Test {
public static void main(String[] args) throws java.io.IOException {
FileTime timestamp = Files.getLastModifiedTime(Paths.get("/tmp/test"));
System.out.println(timestamp.toMillis());
}
}
The output is (with my particular test file) 1405602038000
, whereas ls
shows:
$ ls --full-time /tmp/test
-rw-rw-r-- 1 daniel daniel 0 2014-07-17 16:00:38.413008992 +0300 /tmp/test
I would expect the Java output to be 1405602038413
.
I'm running on Linux with ext4. I tried both openjdk 1.7 and Oracle jdk 1.8.