使用c语言
定义函数: char * getcwd(char * buf, size_t size);
函数说明:getcwd()
会将当前的工作目录绝对路径复制到参数buf 所指的内存空间,参数size 为buf 的空间大小。
#include <unistd.h>
char buf[240]={0};
getcwd(buf, sizeof(buf));
相关函数: stat, lstat, symlink
表头文件: #include <unistd.h>
定义函数:int readlink(const char *path, char *buf, size_t bufsiz);
返回值 :
执行成功则传符号连接所指的文件路径字符串,失败返回-1, 错误代码存于errno。
函数说明:
readlink()
会将参数path的符号链接内容存储到参数buf所指的内存空间,返回的内容不是以’\0’作字符串结尾,但会将字符串的字符数返回,这使得添加’\0’变得简单。- 若参数bufsize小于符号连接的内容长度,过长的内容会被截断,如果 readlink 第一个参数指向一个文件而不是符号链接时,readlink 设置errno 为 EINVAL 并返回 -1。
readlink()
函数组合了open()
、read()
和close()
的所有操作。
错误代码 | 说明 |
---|---|
EACCESS | 取文件时被拒绝,权限不够 |
EINVAL | 参数bufsize为负数 |
EIO | I/O 存取错误 |
ELOOP | 欲打开的文件有过多符号连接问题 |
ENAMETOOLONG | 参数path的路径名称太长 |
ENOENT | 参数path所指定的文件不存在 |
ENOMEM | 核心内存不足 |
ENOTDIR | 参数path路径中的目录存在但却非真正的目录 |
#include <stdio.h>
#include <unistd.h>
char * get_exe_path( char * buf, int count)
{
int i;
int rslt = readlink("/proc/self/cwd", 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;
}
使用qt的库函数
使用qt开发时就相对简单了
QString path = QDir::currentPath();
/// 或者applicationDirPath
QApplication a(argc, argv);
qDebug() << a.applicationDirPath();