在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;
}