Linux获取文件属性 — stat()、fstat()、lstat()

#include   
#include   
#include   
      
int stat(const char *path, struct stat *buf);  
//参数*path:文件路径
//参数*buf:文件信息
//返回值:成功为0,否则为-1

int fstat(int fd, struct stat *buf);  
// 参数fd:文件描述符
//参数*buf:文件信息
//返回值:成功为0,否则为-1
int lstat(const char *path, struct stat *buf);  
//参数*path:文件路径
//参数*buf:返回文件的信息,针对符号链接,lstat 返回链接本身,而不是而非目标文件
//返回值:成功为0,否则为-1

执行失败时候,error被自动设置为下面的值:

EBADF: 文件描述词无效
EFAULT: 地址空间不可访问
ELOOP: 遍历路径时遇到太多的符号连接
ENAMETOOLONG:文件路径名太长
ENOENT:路径名的部分组件不存在,或路径名是空字串
ENOMEM:内存不足
ENOTDIR:路径名的部分组件不是目录

注意:

  • stat() 和 lstat() 都是通过文件路径和文件名访问到文件,然后把文件属性放到 struct stat *buf中;而 fstat() 是通过文件描述符得到文件的属性。

  • 文件本身没有什么权限限制,但是文件的上层目录必须有访问权限才能获取到文件的属性。

  • 当文件是符号链接时,lstat() 返回的是该符号链接本身的信息;而 stat() 返回的是该该符号链接指向的文件的信息。

文件属性结构体

     struct stat {  
       dev_t     st_dev;     /* ID of device containing file */  
       ino_t     st_ino;     /* inode number */  
       mode_t    st_mode;    /* protection */  
       nlink_t   st_nlink;   /* number of hard links */  
       uid_t     st_uid;     /* user ID of owner */  
       gid_t     st_gid;     /* group ID of owner */  
       dev_t     st_rdev;    /* device ID (if special file) */  
       off_t     st_size;    /* total size, in bytes */  
       blksize_t st_blksize; /* blocksize for file system I/O */  
       blkcnt_t  st_blocks;  /* number of 512B blocks allocated */  
       time_t    st_atime;   /* time of last access */  
       time_t    st_mtime;   /* time of last modification */  
       time_t    st_ctime;   /* time of last status change */  
    };  

stat结构体中的st_mode 则定义了下列数种情况:
S_IFMT 0170000 文件类型的位遮罩
S_IFSOCK 0140000 scoket
S_IFLNK 0120000 符号连接
S_IFREG 0100000 一般文件
S_IFBLK 0060000 区块装置
S_IFDIR 0040000 目录
S_IFCHR 0020000 字符装置
S_IFIFO 0010000 先进先出

S_ISUID 04000     文件的(set user-id on execution)位
S_ISGID 02000     文件的(set group-id on execution)位
S_ISVTX 01000     文件的sticky位

S_IRUSR(S_IREAD) 00400     文件所有者具可读取权限
S_IWUSR(S_IWRITE)00200     文件所有者具可写入权限
S_IXUSR(S_IEXEC) 00100     文件所有者具可执行权限

S_IRGRP 00040             用户组具可读取权限
S_IWGRP 00020             用户组具可写入权限
S_IXGRP 00010             用户组具可执行权限

S_IROTH 00004             其他用户具可读取权限
S_IWOTH 00002             其他用户具可写入权限
S_IXOTH 00001             其他用户具可执行权限

上述的文件类型在POSIX中定义了检查这些类型的宏定义:
S_ISLNK (st_mode)    判断是否为符号连接
S_ISREG (st_mode)    是否为一般文件
S_ISDIR (st_mode)    是否为目录
S_ISCHR (st_mode)    是否为字符装置文件
S_ISBLK (s3e)        是否为先进先出
S_ISSOCK (st_mode)   是否为socket

你可能感兴趣的:(Linux)