这是因为执行用户的实际umask设置。
从PosixFileAttributeView
当在文件创建时设置访问权限时,权限的实际值可能与属性对象的值不同。其原因是特定于实现的。例如,在 UNIX 系统上,一个进程有一个 umask,它会影响新创建文件的权限位。如果实现支持设置访问权限,并且底层文件系统支持访问权限,则要求实际访问权限的值等于或小于提供给 createFile 或 createDirectory 方法的属性值. 换句话说,该文件可能比请求的更安全。
例子
Posix.java
// add the omitted import statements
public class Posix {
public static void main(String[] args) throws IOException {
Path newDirectoryPath = Paths.get("/tmp/image");
Files.deleteIfExists(newDirectoryPath);
Set<PosixFilePermission> permissions
= PosixFilePermissions.fromString("rwxrwxrwx");
FileAttribute<Set<PosixFilePermission>> fileAttributes
= PosixFilePermissions.asFileAttribute(permissions);
Files.createDirectories(newDirectoryPath, fileAttributes);
}
}
在shell中执行
$ cd /tmp
$ javac Posix.java
$ umask 001
$ java Posix
$ ls -ld image/
drwxrwxrw-. 2 suboptimal suboptimal 6 Jul 5 12:38 image/
$ umask 002
$ java Posix
$ ls -ld image/
drwxrwxr-x. 2 suboptimal suboptimal 6 Jul 5 12:38 image/
$ umask 004
$ java Posix
$ ls -ld image/
drwxrwx-wx. 2 suboptimal suboptimal 6 Jul 5 12:38 image/