gpt4 book ai didi

C文件操作: Check opened file pointer access mode

转载 作者:行者123 更新时间:2023-11-30 16:22:28 25 4
gpt4 key购买 nike

一个简单的问题:

如何检查已打开的文件指针的访问模式?

假设一个函数传递了一个已经打开的 FILE 指针:

    //Pseudo code
bool PseudoFunction(FILE *Ptr)
{
if( ... Insert check for read-only access rights )
{
//It's read only access mode
return true;
}
//File pointer is not read-only and thus write operations are permitted
return false;
}

我将在 if 语句中使用什么来检查 FILE 指针是否已以只读方式打开(或不是,视情况而定),而不写入文件,并且不依赖于用户传递(可能与)参数?

系统是windows,code::blocks编译器,但出于代码可移植性、交叉兼容性的考虑首选。

注意,这不是询问文件权限,而是询问 FILE 指针使用的访问模式。

自答[由于用户权限限制,无法附加单独的答案]:

下面的另一张海报有一个更好的答案,其中包括正确的#defines

正如之前所建议的,FILE 指针的 _flag(在 _iobuf 下定义)似乎是了解文件是否只读的关键。虽然您的里程可能会有所不同,但相同的基本概念应该很容易适应,示例代码:

#define READ_ONLY_FLAG 1

bool PrintFlagPtr(const char FileName[], const char AccessMode[])
{
FILE *Ptr = NULL;
Ptr = fopen(FileName,AccessMode);
printf("%s: %d ",AccessMode,Ptr->_flag);

int IsReadOnly = Ptr->_flag;
fclose(Ptr);
Ptr = NULL;


if( (IsReadOnly&READ_ONLY_FLAG) == READ_ONLY_FLAG )
{
printf("File is read only!\n");
return true;
}

printf("\n");
return false;
}

当所有不同的访问模式组合与上述函数一起使用时,会产生以下输出:

Output:
w: 2
r: 1 File is read only!
a: 2
wb: 2
rb: 1 File is read only!
ab: 2
w+: 128
r+: 128
a+: 128
w+b: 128
r+b: 128
a+b: 128

我很好奇为什么从未建议(或从未使用过),给定一个交叉兼容的前端函数(只是一个具有相同名称的函数,其声明取决于平台)传递一个来自于的 const int给定 FILE 指针 _flag 将是解决该问题的一个非常简单且容易的方法。

最佳答案

在 Linux(可能还有所有 UNIX 系统)上,您可以使用 fcntl 来获取文件的访问模式:

int get_file_status(FILE* f) {
int fd = fileno(f);
return fcntl(fd, F_GETFL);
}

请注意,返回的值是一个整数,作为 O_RDONLYO_RDWR 等标志的组合,而不是 "r" “w+” 字符串。请参阅http://pubs.opengroup.org/onlinepubs/007908799/xsh/open.html对于其中一些标志。

不确定 Windows,请参阅 On Windows/mingw, what is the equivalent of `fcntl(fd, F_GETFL) | O_ACCMODE`? .

关于C文件操作: Check opened file pointer access mode,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54411412/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com