Linux系統stat函數的用法是什么,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
表頭文件: #include
#include
定義函數: int stat(const char *file_name, struct stat *buf);
函數說明: 通過文件名filename獲取文件信息,并保存在buf所指的結構體stat中
返回值: 執行成功則返回0,失敗返回-1,錯誤代碼存于errno
錯誤代碼: 復制代碼
ENOENT 參數file_name指定的文件不存在 ENOTDIR 路徑中的目錄存在但卻非真正的目錄 ELOOP 欲打開的文件有過多符號連接問題,上限為16符號連接 EFAULT 參數buf為無效指針,指向無法存在的內存空間 EACCESS 存取文件時被拒絕 ENOMEM 核心內存不足 ENAMETOOLONG 參數file_name的路徑名稱太長
復制代碼 復制代碼
#include
int main() { struct stat buf; stat(“/etc/hosts”, &buf); printf(“/etc/hosts file size = %d\n”, buf.st_size); }
/*************************/ struct stat { dev_t st_dev; //文件的設備編號 ino_t st_ino; //節點 mode_t st_mode; //文件的類型和存取的權限 nlink_t st_nlink; //連到該文件的硬連接數目,剛建立的文件值為1 uid_t st_uid; //用戶ID gid_t st_gid; //組ID dev_t st_rdev; //(設備類型)若此文件為設備文件,則為其設備編號 off_t st_size; //文件字節數(文件大小) unsigned long st_blksize; //塊大小(文件系統的I/O 緩沖區大小) unsigned long st_blocks; //塊數 time_t st_atime; //最后一次訪問時間 time_t st_mtime; //最后一次修改時間 time_t st_ctime; //最后一次改變時間(指屬性) };
復制代碼
先前所描述的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
復制代碼
若一目錄具有sticky位(S_ISVTX),則表示在此目錄下的文件只能被該文件所有者、此目錄所有者或root來刪除或改名。
復制代碼
struct statfs { long f_type; //文件系統類型 long f_bsize; //塊大小 long f_blocks; //塊多少 long f_bfree; //空閑的塊 long f_bavail; //可用塊 long f_files; //總文件節點 long f_ffree; //空閑文件節點 fsid_t f_fsid; //文件系統id long f_namelen; //文件名的最大長度 long f_spare[6]; //spare for later };
復制代碼
stat、fstat 和 lstat 函數(UNIX)
#include
int stat(const char *restrict pathname, struct stat *restrict buf);
stat 提供文件名字,獲取文件對應屬性。感覺一般是文件沒有打開的時候這樣操作。
int fstat(int filedes, struct stat *buf);
fstat 通過文件描述符獲取文件對應的屬性。文件打開后這樣操作
int lstat(const char *restrict pathname, struct stat *restrict buf);
lstat 連接文件
三個函數的返回:若成功則為0,若出錯則為-1。
給定一個pathname,stat函數返回一個與此命名文件有關的信息結構,fstat函數獲得已在描述符filedes上打開的文件的有關信息。lstat函數類似于stat,但是當命名的文件是一個符號連接時,lstat返回該符號連接的有關信息,而不是由該符號連接引用的文件的信息。
第二個參數是個指針,它指向一個我們應提供的結構。這些函數填寫由buf指向的結構。該結構的實際定義可能隨實現而有所不同,但其基本形式是: 復制代碼
struct stat{ mode_t st_mode; /file tpye &mode (permissions)/ ino_t st_ino; /i=node number (serial number)/ dev_t st_rdev; /device number for special files/ nlink_t st_nlink; /number of links/ uid_t st_uid; /user id of owner/ gid_t st_gid; /group ID of owner/ off_t st_size; /size in bytes for regular files/ time_t st_atime; /time of last access/ time_t st_mtime; /time of last modification/ time_t st_ctime; /time of last file status change/ long st_blksize; /*best I/O block size / long st_blocks; /number of 512-byte blocks allocated*/ };
復制代碼
注意,除最后兩個以外,其他各成員都為基本系統數據類型。我們將說明此結構的每個成員以了解文件屬性。
使用stat函數最多的可能是ls-l命令,用其可以獲得有關一個文件的所有信息。
函數都是獲取文件(普通文件,目錄,管道,socket,字符,塊)的屬性。
函數原型:
#include
int stat(const char *restrict pathname, struct stat *restrict buf);
提供文件名字,獲取文件對應屬性。
int fstat(int filedes, struct stat *buf);
通過文件描述符獲取文件對應的屬性。
int lstat(const char *restrict pathname, struct stat *restrict buf);
連接文件描述命,獲取文件屬性。
文件對應的屬性 復制代碼
struct stat {
mode_t st_mode; //文件對應的模式,文件,目錄等
ino_t st_ino; //inode節點號
dev_t st_dev; //設備號碼
dev_t st_rdev; //特殊設備號碼
nlink_t st_nlink; //文件的連接數
uid_t st_uid; //文件所有者
gid_t st_gid; //文件所有者對應的組
off_t st_size; //普通文件,對應的文件字節數
time_t st_atime; //文件最后被訪問的時間
time_t st_mtime; //文件內容最后被修改的時間
time_t st_ctime; //文件狀態改變時間
blksize_t st_blksize; //文件內容對應的塊大小
blkcnt_t st_blocks; //文件內容對應的塊數量 };
關于Linux系統stat函數的用法是什么問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。