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


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

     
    相关函数: 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] = '';
        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;
    }
  • 相关阅读:
    观察者模式
    工厂模式
    单例模式
    代理模式
    策略模式
    Ioc容器
    Spring概述
    02:入门
    01:背景
    编译原理感悟
  • 原文地址:https://www.cnblogs.com/timssd/p/4612149.html
Copyright © 2020-2023  润新知