linux下readlink函数的基本用法(获取程序运行路径)

本文详细解析了readlink函数的功能,介绍了如何使用该函数获取符号链接的目标路径,并提供了一个示例代码,展示了如何读取当前进程执行文件的路径。

头文件: #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>
#include<errno.h>
#include<string.h>

char* get_exe_path(char* buf, int count)
{
	int i = 0;
	int result = readlink("/proc/self/exe", buf, count-1);
	if( (result < 0) || (result >= count-1) )
	{
		return NULL;
	}

	buf[result] = '\0';

	for( int i = result; i >=0; i-- )
	{
		if( buf[i] == '/' )
		{
			buf[i+1] = '\0';
			break;
		}
	}

	return buf;
}

int main(int argc, char** argv)
{
	char path[1024];
	if(get_exe_path(path, 1024))
	{
                printf("%s\n", path);
	}
	else
	{
		printf("get exe path error code = %d:%s\n", errno, strerror(errno));
	}
	return 0;
}

 

Re: 《文件和目录操作命令》 =================================== 本人在教学和实战过程中发现,即便是有一定运维经验的人,可能已经能够搭建一定复杂度的Linux架构,但是在来来回回的具体操作中,还是体现出CLI(命令界面)功底不够扎实,甚至操作的非常‘拙’、处处露‘怯’。 对一个士兵来说,枪就是他的武器,对于一个程序员来说,各种library(工具库)就是他的武器;而对于Linux运维人员来说,无疑命令行工具CLI(命令界面)就是他们的武器;高手和小白之间的差距往往就体现在对于这些“武器”的掌握和熟练程度上。有时候一个参数就能够解决的事情,小白们可能要写一个复杂的Shell脚本才能搞定,这就是对CLI(命令界面)没有理解参悟透彻导致。 研磨每一个命令就是擦拭手中的作战武器,平时不保养不理解,等到作战的时候,一定不能够将手中的武器发挥到极致,所以我们要平心、静气和专注,甘坐冷板凳一段时间,才能练就一身非凡的内功! 本教程从实战出发,结合当下流行或最新的Linux(v6/7/8 版本)同时演示,将命令行结合到解决企业实战问题中来,体现出教学注重实战的务实精神,希望从事或未来从事运维的同学,能够认真仔细的学完Linux核心命令的整套课程。 本课程系列将逐步推出,看看我教学的进度和您学习的步伐,孰占鳌头! 注:关于教学环境搭建,可以参考本人其它课程系列,本教学中就不再赘述! 《参透 VMware 桌面级虚拟化》 《在虚拟机中安装模版机(包括应用软件等)》 《SecureCRT 连接 GNS3/Linux 的安全精密工具》---------------------     
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值