std::experimental::filesystem::perms

来自cppreference.com
< cpp‎ | experimental‎ | fs
 
 
实验性
技术规范
文件系统库 (文件系统 TS)
库基础 (库基础 TS)
库基础 2 (库基础 TS v2)
库基础 3 (库基础 TS v3)
并行扩展 (并行 TS)
并行扩展 2 (并行 TS v2)
并发扩展 (并发 TS)
并发扩展 2 (并发 TS v2)
概念 (概念 TS)
范围 (范围 TS)
反射 (反射 TS)
数学特殊函数 (特殊函数 TR)
实验性非 TS 功能特性
模式匹配
线性代数
std::execution
契约
2D 图形
 
 
在标头 <experimental/filesystem> 定义
enum class perms;
(文件系统 TS)

此类型表示文件访问权限。perms 满足 位掩码类型 (BitmaskType) 的要求(这表示按位运算符 operator&operator|operator^operator~operator&=operator|=operator^= 对此类型有定义)。

访问权限模仿 POSIX 权限位,且任何独立文件的权限(如 status 所报告)都是以下位的某种组合:

成员常量

成员常量值(八进制)POSIX 等价物含义
none0未设置任何权限位
owner_read0400S_IRUSR文件所有者有读权限
owner_write0200S_IWUSR文件所有者有写权限
owner_exec0100S_IXUSR文件所有者有执行/搜索权限
owner_all0700S_IRWXU文件所有者有读、写和执行/搜索权限

等价于 owner_read | owner_write | owner_exec

group_read040S_IRGRP文件的用户组有读权限
group_write020S_IWGRP文件的用户组有写权限
group_exec010S_IXGRP文件的用户组有执行/搜索权限
group_all070S_IRWXG文件的用户组有读、写和执行/搜索权限

等价于 group_read | group_write | group_exec

others_read04S_IROTH其他用户有读权限
others_write02S_IWOTH其他用户有写权限
others_exec01S_IXOTH其他用户有执行/搜索权限
others_all07S_IRWXO其他用户有读、写和执行/搜索权限

等价于 others_read | others_write | others_exec

all0777所有用户均有读、写和执行/搜索权限

等价于 owner_all | group_all | others_all

set_uid04000S_ISUID设置执行时的用户 ID 为文件的所有者用户 ID
set_gid02000S_ISGID设置执行时的组 ID 为文件的用户组 ID
sticky_bit01000S_ISVTX由实现定义的含义,但 POSIX XSI 指定在目录上设置时,即便目录对其他人是可写的,也只有文件所有者可以删除文件(用于 /tmp
mask07777所有有效权限位

等价于 all | set_uid | set_gid | sticky_bit

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

成员常量值(十六进制)含义
unknown0xFFFF未知权限(例如当 file_status 不以任何权限创建)
add_perms0x10000指示 permissions 进行添加而非清除权限位的控制位。
remove_perms0x20000指示 permissions 进行清除而非添加权限位的控制位。
resolve_symlinks0x40000指示 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--

参阅

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