在linux中,有時候我們只知道文件描述符卻不知道它的名字及其完整的路徑,如果我們想獲取其路徑該怎么辦呢?其實(shí)很簡單,在linux中每個被打開的文件都會在/proc/self/fd/目錄中有記錄,其中(/proc/self/fd/文件描述符號)的文件就是文件描述符所對應(yīng)的文件。說道這里我們先停下了說一個函數(shù):
readlink(取得符號連接所指的文件)
相關(guān)函數(shù) stat,lstat,symlink
表頭文件 #include <unistd.h>
定義函數(shù) int readlink (const char *path, char *buf, size_t bufsiz);
函數(shù)說明 readlink()會將參數(shù)path的符號連接內(nèi)容存到參數(shù)buf所指的內(nèi)存空間,返回的內(nèi)容不是以NULL作字符串結(jié)尾,但會將字符串的字符數(shù)返回。若參數(shù)bufsiz小于符號連接的內(nèi)容長度,過長的內(nèi)容會被截?cái)唷?/p>
返回值 執(zhí)行成功則傳符號連接所指的文件路徑字符串,失敗則返回-1,錯誤代碼存于errno。
錯誤代碼 EACCESS 取文件時被拒絕,權(quán)限不夠
EINVAL 參數(shù)bufsiz 為負(fù)數(shù)
EIO I/O 存取錯誤。
ELOOP 欲打開的文件有過多符號連接問題。
ENAMETOOLONG 參數(shù)path的路徑名稱太長
ENOENT 參數(shù)path所指定的文件不存在
ENOMEM 核心內(nèi)存不足
ENOTDIR 參數(shù)path路徑中的目錄存在但卻非真正的目錄。
綜合上述得出如下簡單函數(shù)來獲取文件路徑:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
std::string get_file_name (const int fd) { if (0 >= fd) { return std::string (); } char buf[1024] = {'\0'}; char file_path[PATH_MAX] = {'0'}; // PATH_MAX in limits.h snprintf(buf, sizeof (buf), "/proc/self/fd/%d", fd); if (readlink(buf, file_path, sizeof(file_path) - 1) != -1) { return std::string (file_path); } return std::string (); } |
以上這篇linux中通過文件描述符獲取文件絕對路徑的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務(wù)器之家。