• linux关于readlink函数获取运行路径的小程序


    http://blog.csdn.net/djzhao/article/details/8178375
     
    相关函数: stat, lstat, symlink
    表头文件: #include <unistd.h>
    定义函数:int  readlink(const  char *path,  char *buf, size_t  bufsiz);
    函数说明:readlink()会将参数path的符号链接内容存储到参数buf所指的内存空间,返回的内容不是以00作字符串结尾,但会将字符串的字符数返回,这使得添加00变得简单。若参数bufsiz小于符号连接的内容长度,过长的内容会被截断,如果 readlink 第一个参数指向一个文件而不是符号链接时,readlink 设 置errno 为 EINVAL 并返回 -1。 readlink()函数组合了open()、read()和close()的所有操作。

    返回值   :执行成功则传符号连接所指的文件路径字符串,失败返回-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;
     
    /*  /proc/self/exe -> /a/b/c*/
        int rslt = readlink("/proc/self/exe", buf, PATH_MAX);// buf返回"/a/b/c"

        if (rslt < 0 || rslt >= PATH_MAX)
        {
            return NULL;
        }
        buf[rslt] = '';
        for (i = rslt; i >= 0; i--)
        {
            printf("buf[%d] %c ", i, buf[i]);
            if (buf[i] == '/')
            {
                buf[i + 1] = '';
                break;
            }
        }
        return buf;
    }

    int main(int argc, char ** argv)
    {
        printf("%s ", 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] = '';
        for (i = rslt; i >= 0; i--)
        {
            printf("buf[%d] %c ", i, buf[i]);
            if (buf[i] == '/')
            {
                buf[i + 1] = '';
                break;
            }
        }
        return buf;
    }

    int main(int argc, char ** argv)
    {
        char path[1024];
        printf("%s ", get_exe_path(path, 1024));
        return 0;
    }
     
     
  • 相关阅读:
    set
    网络流学习(最小费用最大流)
    网络流学习(最大流)
    模拟退火学习
    NOI Day1T1归程(Kruskal重构树+Dijkstra)
    线性基学习
    高斯消元学习
    manacher算法学习(求最长回文子串长度)
    AC自动机模板2
    AC自动机入门
  • 原文地址:https://www.cnblogs.com/LiuYanYGZ/p/5499286.html
Copyright © 2020-2023  润新知