stat, lstat, fstat, fstatat函数是UNIX提供给我们的访问文件信息的接口.
以下是函数原型:
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
int stat(const char *pathname, struct stat *statbuf);
int fstat(int fd, struct stat *statbuf);
int ltat(const char *pathname, struct stat *statbuf);
int fstatat(int dirfd, const char *pathname, struct stat *statbuf, int flags);
glibc的特征测试宏:
lstat():
_BSD_SOURCE || _DEFAULT_SOURCE || _XOPEN_SOURCE >= 500 ||
_POSIX_C_SOURCE >= 200112L
fstat():
_POSIX_C_SOURCE >= 200809L
_ATFILE_SOURCE
详情见man 2 stat和man 7 feature_test_macros.
fstat用于描述符参数, stat和lstat相同依赖于路径名, 但是当路径名是一个符号链接的时候, stat返回的是该符号链接引用的文件(即源文件),信息 而lstat则返回的是符号链接的信息.
#include "apue.h"
/* symlink.file 是一个符号链接 */
int main(void)
{
struct stat statbuf;
#ifdef L_STAT
if (lstat("symlink.file", &statbuf) < 0)
#else
if (stat("symlink.file", &statbuf) < 0)
#endif
err_sys("Open error");
if (S_ISLNK(statbuf.st_mode))
printf("Symbol link\n");
else
printf("Not Symbol link\n");
exit(-1);
}
以上程序若打开L_STAT则输出Symbol link否则输出Not Symbol link.
最后的函数fstatat, 第一个参数众所周知是一个文件描述符, 该参数若使用标志AT_FDCWD, 则pathname参数使用的是相对路径,
如果pathname是一个绝对路径, 则忽略fd参数, 最后的flags参数若设置了AT_SYMLINK_NOFOLLOW标志则说明fstatat返回符号链接的信息, 否则不返回符号链接的信息.
#include "apue.h"
int main(void)
{
struct stat statbuf;
#ifdef FOLLOW
if (fstatat(AT_FDCWD, "symlink.file", &statbuf, 0) < 0)
#else
if (fstatat(AT_FDCWD, "symlink.file", &statbuf, AT_SYMLINK_NONFOLLOW) < 0)
#endif
err_sys("Open error");
if (S_ISLNK(statbuf.st_mode))
printf("Symbol link\n");
else
printf("Non symbol link\n");
exit(-1);
}
上述代码若打开FOLLOW标志则输出Not symbol link否则输出Symbol link.