struct stat结构体简介

来源:互联网 发布:linux蓝牙终端 编辑:程序博客网 时间:2024/05/22 07:54
struct stat结构体简介

在使用这个结构体和方法时,需要引入:

<sys/types.h>

<sys/stat.h>

struct stat这个结构体是用来描述linux系统中文件系统的文件属性的结构。

可以有两种方法来获取一个文件的属性:

1、通过路径:

int stat(const char *path, struct stat *struct_stat);

int lstat(const char *path,struct stat *struct_stat);

两个函数的第一个参数都是文件的路径,第二个参数是struct stat的指针。返回值为0,表示成功执行。执行失败时,error被自动设置为相应的值。

2、通过文件描述符

int fstat(int fdp, struct stat *struct_stat);  //通过文件描述符获取文件对应的属性;fdp为文件描述符。

 

下面是这个结构的结构

struct stat {

        dev_t    st_dev;    //文件所在的设备:主次设备号

        ino_t    st_info;    //file's inode(文件的索引节点)

        mode_t    st_mode;    //protection mode(保护模式)

        nlink_t    st_nlink;    //number of hard links(硬链接的数量)

        uid_t    st_uid;    //user ID of owner(所有者对应的用户ID)

        gid_t    st_gid;    //group ID of owner(所有者对应的组ID)

        dev_t    st_rdev;    //device type (if inode device)(特殊设备号)

        off_t    st_size;    //total size,in bytes(普通文件,对应的文件字节数)

        blksize_t    st_blksize;    //blocksize for filesystem I/O(文件内容对应的块的大小)

        blkcnt_t    st_blocks;    //number of blacks allocated(文件内容对应的块的数量)

        time_t    st_atime;    //time of last access(文件最后被访问的时间)

        time_t    st_mtime;    //time of last modification(文件内容最后被修改的时间)

        time_t    st_ctime;    //time of last change(文件状态最后被改变的时间)

      };

stat结构体中的st_mode 则定义了下列数种情况:
    S_IFMT   0170000    //决定文件类型的屏蔽码
    S_IFSOCK 0140000    //套接字文件
    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_IRWXU    0700    文件主人可读写执行
    S_IRUSR(S_IREAD)    0400     文件所有者具可读取权限
    S_IWUSR(S_IWRITE)    0200     文件所有者具可写入权限
    S_IXUSR(S_IEXEC)    0100     文件所有者具可执行权限


    S_IRWXG    0070             小组用户可读写执行
    S_IRGRP    0040             用户组具可读取权限
    S_IWGRP    0020             用户组具可写入权限
    S_IXGRP    0010             用户组具可执行权限


    S_IRWXO    0007             其他用户可读写执行
    S_IROTH    0004             其他用户具可读取权限
    S_IWOTH    0002             其他用户具可写入权限
    S_IXOTH    0001             其他用户具可执行权限

    上述的文件类型在POSIX中定义了检查这些类型的宏定义:
    S_ISLNK (st_mode)    判断是否为符号链接文件
    S_ISREG (st_mode)    是否为一般文件
    S_ISDIR (st_mode)    是否为目录
    S_ISCHR (st_mode)    是否为字符设备文件
    S_ISBLK (st_mode)        是否为块设备文件
    S_ISSOCK (st_mode)   是否为网络套接字文件
若一目录具有sticky位(S_ISVTX),则表示在此目录下的文件只能被该文件所有者、此目录所有者或root来删除或改名,在linux中,最典型的就是这个/tmp目录啦。

0 0
原创粉丝点击