相关函数: 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路径中的目录存在但却非真正的目录
示例1:
#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;
}
示例2:
#include <stdio.h>
#include <unistd.h>
// type==1 得到当前全路径 type==0 得到当前目录
char * get_exe_path( char * buf,int count,int type)
{
int i;
int rslt = readlink("/proc/self/exe",count - 1);
if ((rslt < 0) || (rslt >= count - 1))
{
return NULL;
}
buf[rslt] = '\0';
// 只显示当前目录
if (type == 0)
{
for (i = rslt; i >= 0; i--)
{
//printf("buf[%d] %c\n",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;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。