Linux操作系统中的环境变量

环境变量


基本概念

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

常见的环境变量

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

查看环境变量的方法

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

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

参考博客:https://blog.csdn.net/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*的指针指向这个字符串。

扫描二维码关注公众号,回复: 8761009 查看本文章
  • 通过第三方变量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,我们发现环境变量表里也出现了此变量

发布了119 篇原创文章 · 获赞 17 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/tangya3158613488/article/details/99623330
今日推荐