Namespaces
Variants

std::experimental::filesystem:: perms

From cppreference.net
定义于头文件 <experimental/filesystem>
enum class perms ;
(文件系统 TS)

此类型表示文件访问权限。 perms 满足 位掩码类型 的要求(这意味着位运算操作符 operator & operator | operator ^ operator~ operator & = operator | = operator ^ = 已为此类型定义)。

访问权限模型 POSIX权限位 ,以及任何独立文件权限(由 status 报告)均为以下若干位的组合:

目录

成员常量

成员常量 值(八进制) POSIX 等效值 含义
none 0 未设置任何权限位
owner_read 0400 S_IRUSR 文件所有者具有读取权限
owner_write 0200 S_IWUSR 文件所有者具有写入权限
owner_exec 0100 S_IXUSR 文件所有者具有执行/搜索权限
owner_all 0700 S_IRWXU 文件所有者具有读取、写入和执行/搜索权限

等效于 owner_read | owner_write | owner_exec

group_read 040 S_IRGRP 文件的用户组具有读取权限
group_write 020 S_IWGRP 文件的用户组具有写入权限
group_exec 010 S_IXGRP 文件的用户组具有执行/搜索权限
group_all 070 S_IRWXG 文件的用户组具有读取、写入和执行/搜索权限

等效于 group_read | group_write | group_exec

others_read 04 S_IROTH 其他用户具有读取权限
others_write 02 S_IWOTH 其他用户具有写入权限
others_exec 01 S_IXOTH 其他用户具有执行/搜索权限
others_all 07 S_IRWXO 其他用户具有读取、写入和执行/搜索权限

等效于 others_read | others_write | others_exec

all 0777 所有用户具有读取、写入和执行/搜索权限

等效于 owner_all | group_all | others_all

set_uid 04000 S_ISUID 执行时设置用户ID为文件所有者用户ID
set_gid 02000 S_ISGID 执行时设置组ID为文件的用户组ID
sticky_bit 01000 S_ISVTX 实现定义的含义,但POSIX XSI规定当在目录上设置时,即使目录对其他用户可写,也只有文件所有者可以删除文件(用于 / tmp
mask 07777 所有有效权限位

等效于 all | set_uid | set_gid | sticky_bit

此外,还定义了此类型的以下常量,它们不代表权限:

成员常量 值(十六进制) 含义
unknown 0xFFFF 未知权限(例如当 file_status 创建时未指定权限)
add_perms 0x10000 控制位,指示 permissions 添加但不清除权限位
remove_perms 0x20000 控制位,指示 permissions 清除但不添加权限位
resolve_symlinks 0x40000 控制位,指示 permissions 解析符号链接

注释

权限在实现上未必采用位表示,但在概念层面通常按位处理。

某些系统可能会忽略部分权限位,并且修改某些位可能自动改变其他位(例如在没有所有者/组/全体区分的平台上,设置任意一个写入位会同时设置所有三个写入位)。

示例

#include <bitset>
#include <experimental/filesystem>
#include <fstream>
#include <iostream>
namespace fs = std::experimental::filesystem;
void demo_perms(fs::perms p)
{
     std::cout << ((p & fs::perms::owner_read) != fs::perms::none ? "r" : "-")
               << ((p & fs::perms::owner_write) != fs::perms::none ? "w" : "-")
               << ((p & fs::perms::owner_exec) != fs::perms::none ? "x" : "-")
               << ((p & fs::perms::group_read) != fs::perms::none ? "r" : "-")
               << ((p & fs::perms::group_write) != fs::perms::none ? "w" : "-")
               << ((p & fs::perms::group_exec) != fs::perms::none ? "x" : "-")
               << ((p & fs::perms::others_read) != fs::perms::none ? "r" : "-")
               << ((p & fs::perms::others_write) != fs::perms::none ? "w" : "-")
               << ((p & fs::perms::others_exec) != fs::perms::none ? "x" : "-")
               << '\n';
}
int main()
{
    std::ofstream("test.txt"); // 创建文件
    std::cout << "创建文件的权限: ";
    demo_perms(fs::status("test.txt").permissions());
    fs::permissions("test.txt", fs::perms::add_perms |
                                fs::perms::owner_all | fs::perms::group_all);
    std::cout << "添加 o+rwx 和 g+rwx 后:  ";
    demo_perms(fs::status("test.txt").permissions());
    fs::remove("test.txt");
}

可能的输出:

创建文件的权限: rw-r--r--
添加 o+rwx 和 g+rwx 后:  rwxrwxr--

参见

确定文件属性
确定文件属性,检查符号链接目标
(function)
修改文件访问权限
(function)