linux關於readlink函式獲取執行路徑的小程式

2puT發表於2016-07-13
相關函式: stat, lstat, symlink
表標頭檔案: #include <unistd.h>
定義函式:int  readlink(const  char *path,  char *buf, size_t  bufsiz);
函式說明:readlink()會將引數path的符號連線內容到引數buf所指的記憶體空間,返回的內容不是以NULL作字串結尾,但會將字串的字元數返回。若引數bufsiz小於符號連線的內容長度,過長的內容會被截斷

返回值   :執行成功則傳符號連線所指的檔案路徑字串,失敗返回-1, 錯誤程式碼存於errno
錯誤程式碼:
               EACCESS                  取檔案時被拒絕,許可權不夠
               EINVAL                    引數bufsiz為負數
               EIO                         O存取錯誤
               ELOOP                     欲開啟的檔案有過多符號連線問題
               ENAMETOOLONG       引數path的路徑名稱太長
               ENOENT                   引數path所指定的檔案不存在
               ENOMEM                   核心記憶體不足
               ENOTDIR                   引數path路徑中的目錄存在但卻非真正的目錄

例一:
#include <stdio.h>
#include <unistd.h>
#define PATH_MAX 1024
char * get_exe_path()
{
    static char buf[PATH_MAX];
    int i;
    int rslt = readlink("/proc/self/exe", buf, PATH_MAX);
    if (rslt < 0 || rslt >= PATH_MAX)
    {
        return NULL;
    }
    buf[rslt] = '\0';
    for (i = rslt; i >= 0; i--)
    {
        printf("buf[%d] %c\n", i, buf[i]);
        if (buf[i] == '/')
        {
            buf[i + 1] = '\0';
            break;
        }
    }
    return buf;
}

int main(int argc, char ** argv)
{
    printf("%s\n", get_exe_path());
    return 0;
}

例二:(個人感覺這個程式比較合理, 推薦)
#include <stdio.h>
#include <unistd.h>
char * get_exe_path( char * buf, int count)
{
    int i;
    int rslt = readlink("/proc/self/exe", buf, count - 1);
    if (rslt < 0 || (rslt >= count - 1))
    {
        return NULL;
    }
    buf[rslt] = '\0';
    for (i = rslt; i >= 0; i--)
    {
        printf("buf[%d] %c\n", i, buf[i]);
        if (buf[i] == '/')
        {
            buf[i + 1] = '\0';
            break;
        }
    }
    return buf;
}

int main(int argc, char ** argv)
{
    char path[1024];
    printf("%s\n", get_exe_path(path, 1024));
    return 0;
}

相關文章