在linux世界中,“环境变量”是一个至关重要的概念。它不仅决定了系统的运行环境,也影响着我们日常的命令执行和程序编译。本文将带你深入了解linux环境变量的方方面面。

1. 初识环境变量
简单来说,环境变量(environment variables)是在操作系统中用来指定其运行环境的一些参数。例如,当我们编译代码时,编译器之所以能自动找到所需的库文件,就是因为有相关的环境变量在“引路”。环境变量通常具有全局性,对系统中的所有进程都有效。
以下是几个最常见的环境变量:
`PATH`:指定了当你在终端输入一个命令时,系统去哪些目录中搜索这个命令对应的可执行文件。
`HOME`:指定了当前用户的主工作目录,也就是你登录系统后默认进入的目录。
`PWD`:记录了你当前所在的目录路径。
要查看系统中所有的环境变量,可以使用`env`命令。

2. 在程序中获取环境变量
我们有多种方式可以在C/C++程序中获取环境变量的值。
方法一:使用`getenv()`函数
C语言标准库提供了一个非常便捷的函数`getenv()`,你可以通过它来获取指定环境变量的值。

下面是一个简单的示例代码:

运行结果如下,成功获取了`PATH`变量的值:

方法二:通过`main`函数的参数
当系统启动一个程序时,会向`main`函数传递两张表:一张是命令行参数表(`argv`),另一张就是环境变量表(`envp`)。我们可以通过`main`函数的第三个参数来接收这张表。

示例代码如下,通过遍历`envp`数组来打印所有环境变量:

运行后,可以看到程序成功打印出了完整的环境变量列表:

方法三:使用全局变量`environ`
系统中还有一个名为`environ`的全局变量,它是一个指向环境变量表的指针。通过声明`extern char **environ;`,我们也可以在程序中访问它。

商汤商量
商汤科技研发的AI对话工具,商量商量,都能解决。
36 查看详情
3. 环境变量与配置文件
当我们在命令行中修改环境变量(例如,将`PATH`置空)时,会发现很多命令都无法使用了。但只要重新登录,一切又恢复正常。

这是因为,我们在命令行中所做的修改,只是暂时改变了当前Shell进程(bash)内存中的环境变量信息。每次重新登录,系统都会启动一个新的bash进程,并从一个配置文件(通常是用户主目录下的`.bash_profile`)中重新加载环境变量。

因此,如果你想永久地修改或添加环境变量,就需要去编辑这个配置文件。
4. 本地变量与环境变量的区别
在bash中,我们可以直接使用`变量名=内容`的方式定义一个变量。但这种方式创建的只是一个“本地变量”。

本地变量只在当前的Shell进程中有效,不会被它所创建的子进程继承。因此,你在程序中无法通过`getenv()`获取到它。

要将一个本地变量“升级”为环境变量,需要使用`export`命令。

更简洁的写法是,在定义时就直接使用`export`。

需要注意的是,通过`export`设置的环境变量同样是临时的,只在当前登录会话中有效。要使其永久生效,仍需写入配置文件。

5. 环境变量的全局性(继承性)
环境变量的一个重要特性就是它可以被子进程继承,从而实现全局性。我们可以通过一个简单的`fork()`程序来验证这一点:子进程可以完整地打印出父进程(即bash)的所有环境变量。
运行结果证明了子进程确实继承了环境变量:

但如果我们尝试在程序中获取一个未被`export`的本地变量,结果会是`NULL`,这再次印证了本地变量与环境变量的核心区别。
6. 内建命令与常规命令
一个有趣的现象是,即使我们将`PATH`变量置空,导致像`ls`、`vim`这样的常规命令失效,但`pwd`、`cd`、`echo`等命令依然可以正常使用。
这是因为Linux命令分为两类:常规命令是独立的可执行文件,需要通过`PATH`来查找;而内建命令是Shell自身实现的一部分(可以理解为函数),因此它们不依赖`PATH`环境变量,可以直接执行。
以上就是深入理解Linux环境变量的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/372172.html
微信扫一扫
支付宝扫一扫