Bootstrap

重生之我在学环境变量

环境变量

在这里插入图片描述

基本概念

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

命令行参数

在这里插入图片描述

argv是指针数组

在这里插入图片描述

把上面的字符串切成一个一个字符,放到对应的下标里面,组成了一个字符串argc

命令行参数可以把一个程序不同子功能,像选项一样实现

在这里插入图片描述

我们之前写代码,用main函数,main函数的命令行参数,是实现程序不同子功能的方法

通过bash进行切分,划分不同的命令行参数

1)要执行一个程序,必须要先找到它。

2)系统中存在环境变量,来帮助系统找到目标二进制文件

在这里插入图片描述

环境变量是PATH,系统中搜索指令的默认搜索路径用$

1)如何理解环境变量?

bash会形成一张表,叫做环境变量表,这张表类似于指针数组,当我们输入ls指令的时候,bash会拿到相应的表,叫做命令行参数表,所以说bash有两张表

2)环境变量,最开始从哪里来?

是从系统的相关配置文件中来的

在这里插入图片描述

认识更多的环境变量

在这里插入图片描述

常⻅环境变量

  • PATH:指定命令的搜索路径
  • HOME:指定⽤⼾的主⼯作⽬录(即⽤⼾登陆到Linux系统中时,默认的⽬录)
  • SHELL:当前Shell,它的值通常是/bin/bash。

查看环境变量⽅法

echo $NAME //NAME:你的环境变量名称

测试PATH

创建hello.c⽂件

#include <stdio.h>
 int main()
 {
 printf("hello world!\n");
 return 0;
 }
  1. 对⽐./hello执⾏和之间hello执⾏
  2. 为什么有些指令可以直接执⾏,不需要带路径,⽽我们的⼆进制程序需要带路径才能执⾏?
  3. 将我们的程序所在路径加⼊环境变量PATH当中,
  4. 对⽐测试 export PATH=$PATH:hello 程序所在路径

测试HOME

  1. ⽤root和普通⽤⼾,分别执⾏
  2. 执⾏ echo $HOME ,对⽐差异 cd ~; pwd ,对应 ~ 和 HOME 的关系

和环境变量相关的命令

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

环境变量的组织⽅式

在这里插入图片描述

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

补充说明:

命令行参数会被bash用,接着被用户间接地使用

通过代码如何获取环境变量

  • 命令第三个参数
#include <stdio.h>
 int main(int argc, char *argv[], char *env[])
 {
 int i = 0;
 for(; env[i]; i++){
 printf("%s\n", env[i]);
 }
 return 0;
 }
  • 通过第三方environ获取
#include <stdio.h>
 int main(int argc, char *argv[])
 {
 extern char **environ;
 int i = 0;
 for(; environ[i]; i++){
 printf("%s\n", environ[i]);
 }
 return 0;
 }

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

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

  • getenv
 #include <stdio.h>
 #include <stdlib.h>
 int main()
 {
 printf("%s\n", getenv("PATH"));
 return 0;
 }

常⽤getenv函数来访问特定的环境变量。

我们更推荐getenv的方式获得环境变量,另外两种方法都是只能得到链表,也就是地址,不能得到具体的内容,我们想要得到环境变量还是更想要内容

环境变量通常是具有全局属性的

  • 环境变量通常具有全局属性,可以被子进程继承下去
#include <stdio.h>
 #include <stdlib.h>
 int main()
 {
 char *env = getenv("MYENV");
 if(env){
 printf("%s\n", env);
 }
 return 0;
 }

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

  • 导出环境变量
export MYENV="hello world"
  • 再次运⾏程序,发现结果有了!说明:环境变量是可以被⼦进程继承下去的!

在这里插入图片描述

理解环境变量的特性

1.环境变量具有全局性

2.补充两个概念

1)本地变量

不会被子进程继承,只在bash内部使用

bash会记录1.环境2.本地

2)我们的变量究竟在谁里面?

在bash里面。

在这里插入图片描述

如果只进⾏ MYENV = “helloworld” ,不调⽤export导出,在⽤我们的程序查看,会有什么结 果?为什么?

  • 普通变量
    地变量

不会被子进程继承,只在bash内部使用

bash会记录1.环境2.本地

2)我们的变量究竟在谁里面?

在bash里面。

[外链图片转存中…(img-VwSXgT6M-1732280661671)]

实验

如果只进⾏ MYENV = “helloworld” ,不调⽤export导出,在⽤我们的程序查看,会有什么结 果?为什么?

  • 普通变量
  • 如果时间允许:做⼀下~/. bash_profile&&~/.bashrc修改⽂件级环境变量
;