Linux:环境变量

环境变量

我们在编写C代码的时候,在链接的时候,我们从来不知道所链接的动态静态库在哪里,但是照样可以链接成功,生成可执行程序,原因就是有环境变量帮助编译器进行查找。

一、常见环境变量

  • PATH:指定命令的搜索路径
  • HOME:指定用户的主中做目录
  • HISTSIZE:保存历史命令记录的条数
  • SHELL:当前shell,它的值通常是/bin/bash

二、查看环境变量

env:查看系统的环境变量
echo $:可查看具体环境变量内容
set:查看全体环境变量
export:导出环境变量

PATH

echo $PATH

这里写图片描述

我们知道,在Linux下,我们的命令,如:ls、rm、mv等都是一个个程序,我们在使用它们的时候直接可以使用。那么我们自己写的C代码生成可执行文件后,为什么不能直接执行,而需要用 ./ 操作符来执行呢?

这里写图片描述

原因是因为我们所执行的命令,它们都在环境变量的路径底下,当我们执行的时候,环境变量则会去路径下寻找执行的命令,这样就不用加 ./来执行了。那么如果我们把 hello 放到PATH环境变量下,是不是也不用加./了呢?
这里写图片描述

事实确实是这样的。

HOME

echo $HOME

这里写图片描述

我们发现在不同的用户下HOME环境变量下的内容是不同的, 因为环境变量HOME保存的是我们用户的工作目录,即用户打开终端默认的目录。所以这也是我们在查看HOME时,其内容不一样的原因。

HISTSIZE

echo $HISTSIZE

这里写图片描述

HISTSIZE环境变量是历史保存的命令的个数,我们在使用Linux时,用上下左右可以切换最近使用的命令,而这些命令总功能够保存1000条,也就是由HISTSIZE来决定最多能保存多少条命令的。

三、通过函数调用来获取环境变量

#include <stdio.h>
#include <stdlib.h>

int main()
{
    printf("%s\n",getenv("PATH"));

    return 0;
}

我们常用getenv来访问特定的环境变量。
这里写图片描述

这里写图片描述

四、环境变量的全局特性

#include <stdio.h>

#inlucde <stdlib.h>

int main()
{
    char* env = getenv("MYENV");
    if(env)
    {
        printf("%s\n",env);
    }
    return 0;
}

我们先利用getenv函数来获取我们自己的环境变量。但是这时候我们并没有定义这个环境变量。
这里写图片描述

显而易见我们并没有定义MYENV这个环境变量,所以也就打不出来。我们现在去定义这个环境变量,利用export。
这里写图片描述

我们发现,在我们定义MYENV之后,再次运行刚才文件,发现这时候打出来了这个MYENV环境变量,也就是说,当我们定义好环境变量以后,在接下来的所有子进程当中,应当继承这个环境变量。所以这也叫做环境变量的全局特性。


欢迎大家共同讨论,如有错误及时联系作者指出,并改正。谢谢大家!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值