Linux操作系统中的环境变量

本文深入解析环境变量的概念,包括其在操作系统中的作用、常见环境变量如PATH、HOME、SHELL的功能,以及如何在Linux环境下查看、设置和管理环境变量。同时,文章提供了通过代码和系统调用获取环境变量的方法,以及环境变量的全局特性和子进程继承机制。

环境变量


基本概念

  • 环境变量(environment varibles)一般是指在操作系统中用来指定操作系统运行环境的一些参数。环境变量是由系统定义的。如:在编写C/C++代码的时候,在链接的时候,我们也许一直都不知道我们所链接的动静态库在哪里,但是照样可以链接成功,生成可执行程序,原因在于有相关环境变量帮助编译器进行查找。
  • 环境变量通常具有某些特殊用途,还有在系统当中通常具有全局特性。

常见的环境变量

  • PATH:指定命令的搜索路径。用echo $PATH 查看。
  • HOME:指定用户的主目录(即用户登录到Linux系统中时,默认的目录)。用echo $PATH查看
  • SHELL:当前Shell,它的值通常是/bin/bash

查看环境变量的方法

echo $NAME,NAME是你的环境变量名称

Linux下查看和添加PATH环境变量

参考博客:https://blog.youkuaiyun.com/qingkongyeyue/article/details/52733203

环境变量相关的命令

  1. echo:设置某个环境变量值
  2. export:设置一个新的环境变量
  3. env:显示所有环境变量
  4. unset:清楚环境变量
  5. set:显示本地定义的shell变量和环境变量

环境变量的组织方式

每个程序都会收到一张环境表,环境表是一个字符指针数组,每个指针指向一个以'\0'结尾的环境字符串。

通过代码获取环境变量

  • 通过命令行第三个参数获得

这里解释一下main函数中的三个参数。argc是指命令行参数的个数,argv是把命令行中的参数的内容以空格作为分隔符依次在0-n下标指向的argv数组中。以代码来验证:

char* env[]就是上图的环境表。如果我们新建一个环境字符串,用一个char*的指针指向这个字符串。

  • 通过第三方变量environ获取

效果和第一种相同。

lib中定义的全局变量environ指向环境变量表,environ没有包含在任何头文件中,所以在使用时要用extern声明

通过系统调用获取或设置环境变量

  • putenv函数
  • getenv函数

putenv函数

头文件:

#include<stdlib.h>

定义函数:

int putenv(const char * string);

函数说明:

putenv()用来改变或增加环境变量的内容. 参数string 的格式为name=value, 如果该环境变量原先存在, 则变量内容会依参数string 改变, 否则此参数内容会成为新的环境变量.

返回值:执行成功则返回0, 有错误发生则返回-1.

错误代码:ENOMEM 内存不足, 无法配置新的环境变量空间.

范例:

#include <stdlib.h>
int main()
{
      char *p;
      if(p = getenv("USER"))
          printf("USER =%s\n", p);
      putenv("USER=test");
      printf("USER=%s\n", getenv("USER"));
}

执行结果:

getenv函数

头文件:

#include<stdlib.h>

定义函数:

char * getenv(const char *name);

函数说明:

getenv()用来取得参数name 环境变量的内容. 参数name 为环境变量的名称, 如果该变量存在则会返回指向该内容的指针. 环境变量的格式为name=value.

返回值:执行成功则返回指向该内容的指针, 找不到符合的环境变量名称则返回NULL.

范例:

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

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

运行结果:

常用putenv和getenv函数来访问特定的环境变量。

环境变量的全局属性

环境变量通常具有全局属性,可以被子进程继承下去。

直接查看,发现没有结果,说明该环境变量根本不存在。

  • 导出环境变量,用export

再次运行程序,发现有结果了,说明环境变量是可以被子进程继承下去。这是为什么呢?

这是因为内存配置的关系。

  • 当启动一个shell,操作系统会分配一个记忆块给shell使用,此内存内的变量可让子进程取用。
  • 若在父进程利用export功能,可以让自定义变量的内容写到上述的记忆块当中(环境变量)。
  • 当加载另一个shell时(即启动子进程,而离开原本的父进程了),子shell可以将父shell的环境变量所在的所有记忆块导入自己的环境变量块当中。
  • 如果只进行MYENV="hello world",不调用export,再进行查看,会有什么结果?

我们发现,运行后什么也没有。使用export导入后,运行结果就有了,再运行./env,我们发现环境变量表里也出现了此变量

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值