在linux中每个被打开的文件都会在/proc/self/fd/目录中有记录,其中(/proc/self/fd/文件描述符号;这个文件是符号文件)的文件就是文件描述符所对应的文件。
而readlink可以取得符号连接所指的文件
函数原型:
ssize_t readlink(const char *path, char *buf, size_t bufsiz);
函数说明:
readlink()会将参数path的符号连接内容存到参数buf所指的内存空间,返回的内容不是以NULL作字符串结尾,但会将字符串的字符数返回。若参数bufsiz小于符号连接的内容长度,过长的内容会被截断。
返回值 执行成功则传符号连接所指的文件路径字符串,失败则返回-1,错误代码存于errno。
错误代码
EACCESS 取文件时被拒绝,权限不够
EINVAL 参数bufsiz 为负数
EIO I/O 存取错误。
ELOOP 欲打开的文件有过多符号连接问题。
ENAMETOOLONG 参数path的路径名称太长
ENOENT 参数path所指定的文件不存在
ENOMEM 核心内存不足
ENOTDIR 参数path路径中的目录存在但却非真正的目录。
通过文件描述符获取文件名源码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include <string.h>
const char *FILE_NAME = "a.txt";
int main(){
int fd;
if((fd = open(FILE_NAME, O_RDONLY)) == -1){
fprintf(stderr,"%s open :%s\n",FLOW_RX_FILE, strerror(errno));
return -1;
}
char buf[1024] = {‘\0‘};
char file_path[1024] = {‘\0‘};
snprintf(buf,sizeof(buf), "/proc/self/fd/%d", fd);
readlink(buf,file_path,sizeof(file_path)-1);
printf("%s\n",file_path);
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
时间: 2024-11-07 17:46:34