相关函数: 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; } |
|