函數原型;ubuntu
#include<unistd.h> ssize_t readlink(const char *path, char *buf, size_t bufsiz);
函數說明:數組
readlink()會將參數path的符號連接內容存儲到參數buf所指的內存空間,返回的內容不是以\000做字符串結尾,但會將字符串的字符數返回,這使得添加\000變得簡單。若參數bufsiz小於符號鏈接的內容長度,過長的內容會被截斷,若是 readlink 第一個參數指向一個文件而不是符號連接時,readlink 設 置errno 爲 EINVAL 並返回 -1。 readlink()函數組合了open()、read()和close()的全部操做。函數
path是一個存在的軟鏈接。spa
返回值:code
執行成功則返回字符串的字符數,失敗返回-1, 錯誤代碼存於errno。blog
錯誤代碼:內存
EACCESS 取文件時被拒絕,權限不夠字符串
EINVAL 參數bufsiz爲負數get
EIO O存取錯誤原型
ELOOP 欲打開的文件有過多符號鏈接問題
ENAMETOOLONG 參數path的路徑名稱太長
ENOENT 參數path所指定的文件不存在
ENOMEM 核心內存不足
ENOTDIR 參數path路徑中的目錄存在但卻非真正的目錄
實例:
/*** readlink.c ***/ #include<stdio.h> #include<errno.h> #include<unistd.h> char *get_exe_path(char *buf, int count) { int i; int result = readlink("/home/ubuntu14-04/workspace/abcd",buf,count - 1); if (result < 0 || (result >= count - 1)) { perror("readlink "); return NULL; } buf[result] = '\0'; for (i = result; i >= 0; i--) { printf("buf[%d] %c\n",i,buf[i]); if (buf[i] == '/') { buf[i+1] = '\0'; break; } } return buf; } int main() { char path[1024]; printf("%s\n",get_exe_path(path,1024)); return 0; }
運行結果: