Linux系统函数之文件系统管理---stat函数

本文转载自https://blog.csdn.net/qq_40839779/article/details/82789217

Linux系统函数之文件系统管理(二)

stat函数

作用:获取文件信息

头文件include #include #include

函数原型int stat(const char *path, struct stat *buf)

​ 返回值:成功返回0,失败返回-1;

​ 参数:文件路径(名),struct stat 类型的结构体

struct stat 结构体详解:


   
   
   
   
  1. struct stat
  2. {
  3.   dev_t     st_dev;     /* ID of device containing file */文件使用的设备号
  4.   ino_t     st_ino;     /* inode number */ 索引节点号
  5.   mode_t   st_mode;   /* protection */ 文件对应的模式,文件,目录等
  6.   nlink_t   st_nlink;   /* number of hard links */ 文件的硬连接数  
  7.   uid_t     st_uid;     /* user ID of owner */ 所有者用户识别号
  8.   gid_t     st_gid;     /* group ID of owner */ 组识别号  
  9.   dev_t     st_rdev;   /* device ID (if special file) */ 设备文件的设备号
  10.   off_t     st_size;   /* total size, in bytes */ 以字节为单位的文件容量  
  11.   blksize_t st_blksize; /* blocksize for file system I/O */ 包含该文件的磁盘块的大小  
  12.   blkcnt_t st_blocks; /* number of 512B blocks allocated */ 该文件所占的磁盘块  
  13.   time_t   st_atime;   /* time of last access */ 最后一次访问该文件的时间  
  14.   time_t   st_mtime;   /* time of last modification */ /最后一次修改该文件的时间  
  15.   time_t   st_ctime;   /* time of last status change */ 最后一次改变该文件状态的时间  
  16. };

stat结构体中的st_mode 则定义了下列数种情况:


   
   
   
   
  1.   S_IFMT   0170000   文件类型的位遮罩
  2.   S_IFSOCK 0140000   套接字
  3.   S_IFLNK 0120000     符号连接
  4.   S_IFREG 0100000     一般文件
  5.   S_IFBLK 0060000     区块装置
  6.   S_IFDIR 0040000     目录
  7.   S_IFCHR 0020000     字符装置
  8.   S_IFIFO 0010000     先进先出
  9.   S_ISUID 04000     文件的(set user-id on execution)位
  10.   S_ISGID 02000     文件的(set group-id on execution)位
  11.   S_ISVTX 01000     文件的sticky位
  12.   S_IRUSR(S_IREAD) 00400     文件所有者具可读取权限
  13.   S_IWUSR(S_IWRITE)00200     文件所有者具可写入权限
  14.   S_IXUSR(S_IEXEC) 00100     文件所有者具可执行权限
  15.   S_IRGRP 00040             用户组具可读取权限
  16.   S_IWGRP 00020             用户组具可写入权限
  17.   S_IXGRP 00010             用户组具可执行权限
  18.   S_IROTH 00004             其他用户具可读取权限
  19.   S_IWOTH 00002             其他用户具可写入权限
  20.   S_IXOTH 00001             其他用户具可执行权限
  21.   上述的文件类型在POSIX中定义了检查这些类型的宏定义:
  22.   S_ISLNK (st_mode)   判断是否为符号连接
  23.   S_ISREG (st_mode)   是否为一般文件
  24.   S_ISDIR (st_mode)   是否为目录
  25.   S_ISCHR (st_mode)   是否为字符装置文件
  26.   S_ISBLK (s3e)       是否为先进先出
  27.   S_ISSOCK (st_mode)   是否为socket
  28.   若一目录具有sticky位(S_ISVTX),则表示在此目录下的文件只能被该文件所有者、此目录所有者或root来删除或改名,在linux中,最典型的就是这个/tmp目录啦。

st_mode 的结构

st_mode 主要包含了 3 部分信息:

  • 15-12 位保存文件类型

  • 11-9 位保存执行文件时设置的信息

  • 8-0 位保存文件访问权限

你可能感兴趣的:(学习,linux)