- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详细对比C语言中的chmod()函数和fchmod()函数由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
C语言chmod()函数:修改文件权限 头文件:
1
|
#include <sys/types.h> #include <sys/stat.h>
|
定义函数:
1
|
int
chmod(
const
char
* path, mode_t mode);
|
函数说明:chmod()会依参数mode 权限来更改参数path 指定文件的权限.
参数 mode 有下列数种组合: 1、S_ISUID 04000 文件的 (set user-id on execution)位 2、S_ISGID 02000 文件的 (set group-id on execution)位 3、S_ISVTX 01000 文件的sticky 位 4、S_IRUSR (S_IREAD) 00400 文件所有者具可读取权限 5、S_IWUSR (S_IWRITE)00200 文件所有者具可写入权限 6、S_IXUSR (S_IEXEC) 00100 文件所有者具可执行权限 7、S_IRGRP 00040 用户组具可读取权限 8、S_IWGRP 00020 用户组具可写入权限 9、S_IXGRP 00010 用户组具可执行权限 10、S_IROTH 00004 其他用户具可读取权限 11、S_IWOTH 00002 其他用户具可写入权限 12、S_IXOTH 00001 其他用户具可执行权限 。
注:只有该文件的所有者或有效用户识别码为0,才可以修改该文件权限.
基于系统安全,如果欲将数据写入一执行文件,而该执行文件具有S_ISUID 或S_ISGID 权限,则这两个位会被清除。如果一目录具有S_ISUID 位权限,表示在此目录下只有该文件的所有者或root 可以删除该文件.
返回值:权限改变成功返回0, 失败返回-1, 错误原因存于errno. 。
错误代码: 1、EPERM 进程的有效用户识别码与欲修改权限的文件拥有者不同, 而且也不具root 权限. 2、EACCESS 参数path 所指定的文件无法存取. 3、EROFS 欲写入权限的文件存在于只读文件系统内. 4、EFAULT 参数path 指针超出可存取内存空间. 5、EINVAL 参数mode 不正确 6、ENAMETOOLONG 参数path 太长 7、ENOENT 指定的文件不存在 8、ENOTDIR 参数path 路径并非一目录 9、ENOMEM 核心内存不足 10、ELOOP 参数path 有过多符号连接问题. 11、EIO I/O 存取错误 。
范例 。
1
2
3
4
5
6
7
|
/* 将/etc/passwd 文件权限设成S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH */
#include <sys/types.h>
#include <sys/stat.h>
main()
{
chmod(
"/etc/passwd"
, S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH);
}
|
C语言fchmod()函数:修改文件的权限 头文件:
1
|
#include <sys/types.h> #include <sys/stat.h>
|
定义函数:
1
|
int
fchmod(
int
fildes, mode_t mode);
|
函数说明:fchmod()会依参数mode 权限来更改参数fildes 所指文件的权限。参数fildes 为已打开文件的文件描述词。参数mode 请参考chmod ().
返回值:权限改变成功则返回0, 失败返回-1, 错误原因存于errno. 。
错误代码: 1、EBADF 参数fildes 为无效的文件描述词。 2、EPERM 进程的有效用户识别码与欲修改权限的文件所有者不同, 而且也不具root 权限。 3、EROFS 欲写入权限的文件存在于只读文件系统内。 4、EIO I/O 存取错误.
范例 。
1
2
3
4
5
6
7
8
9
|
#include <sys/stat.h>
#include <fcntl.h>
main()
{
int
fd;
fd = open(
"/etc/passwd"
, O_RDONLY);
fchmod(fd, S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH);
close(fd);
}
|
最后此篇关于详细对比C语言中的chmod()函数和fchmod()函数的文章就讲到这里了,如果你想了解更多关于详细对比C语言中的chmod()函数和fchmod()函数的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这是我尝试对文件应用权限的部分代码。 fd=fopen(file_name,"wb"); fchmod(fd,(mode_t)perm); 其中 perm 是一个整数。例如:644 或 755我试过不
程序: #include #include #include #include void main() { int fd=open("b.txt",O_RDONLY); fchmod(
我有一个使用 fchmod 的函数 createFile: int createFile(char *pFileName) { int ret; if ((ret = open(pFile
使用 fchmod(int fildes, mode_t mode) 是否比使用 chmod(const char * path, mode_t mode) 更好? 最佳答案 这几乎是一样的。 chm
我想用 Python 更改文件模式。 os 模块具有三个功能上看似相同的功能: os.chmod os.fchmod os.lchmod 这三个版本有什么区别? 最佳答案 chmod 用于更改路径指定
我是一名优秀的程序员,十分优秀!