【Linux】环境变量

文章目录

  • [1. 基本概念](#1. 基本概念)
  • [2. 常见环境变量](#2. 常见环境变量)
  • [3. 查看环境变量方法](#3. 查看环境变量方法)
  • [4. 测试PATH](#4. 测试PATH)
  • [5. 测试HOME](#5. 测试HOME)
  • [6. 与环境变量相关的命令](#6. 与环境变量相关的命令)
  • [7. 环境变量的组织方式](#7. 环境变量的组织方式)
  • [8. 通过代码如何获取环境变量](#8. 通过代码如何获取环境变量)
  • [9. 通过系统调用获取或设置环境变量](#9. 通过系统调用获取或设置环境变量)
  • [10. 环境变量通常是具有全局属性的](#10. 环境变量通常是具有全局属性的)

1. 基本概念

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

2. 常见环境变量

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

3. 查看环境变量方法

powershell 复制代码
echo $NAME	# NAME:你的环境变量名称

4. 测试PATH

  1. 创建 hello.c 文件
c 复制代码
#include <stdio.h>

int main()
{
	printf("hello world!\n");
	return 0;
}
  1. 对比 ./hello 执行和直接 hello 执行。
  2. 为什么有些指令可以直接执行,不需要带路径,而我们的二进制程序需要带路径才能执行?
  3. 将我们的程序所在路径加入环境变量 PATH 中,export PATH=$PATH:hello程序所在路径
  4. 对比测试。
  5. 还有什么方法可以不用带路径,直接就可以运行呢?

5. 测试HOME

  1. 用 root 和普通用户,分别执行echo $HOME,对比差异。
  2. 执行cd ~pwd,对应~HOME的关系。

6. 与环境变量相关的命令

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

7. 环境变量的组织方式

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

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

  • 命令行第三个参数
c 复制代码
#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 获取
c 复制代码
#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 声明。

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

  • putenv
  • getenv
c 复制代码
#include <stdio.h>
#include <stdlib.h>

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

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

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

  • 环境变量通常具有全局属性,可以被子进程继承下去。
c 复制代码
#include <stdio.h>
#include <stdlib.h>

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

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

  • 导出环境变量export MYENV="hello world"
  • 再次运行程序,发现结果有了!说明:环境变量是可以被子进程继承下去的!想想为什么?
  • 如果只进行MYENV="hello world",不调用 export 导出,再用我们的程序查看,会有什么结果?为什么?

本文待续

相关推荐
Fanche40440 分钟前
MySQL 8 自动安装脚本(CentOS-7 系统)
linux·运维·数据库·mysql·centos
W_kiven2 小时前
Centos安装Dockers+Postgresql13+Postgis3.1
linux·运维·docker·postgresql·centos
liulilittle2 小时前
FTTR 全屋光纤架构分享
linux·服务器·网络·ip·通信·光纤·fttr
niuTaylor4 小时前
从入门到精通:CMakeLists.txt 完全指南
linux·服务器·cmake
思扬09285 小时前
Docker多阶段构建深度优化指南:从GB到MB的镜像瘦身革命
运维·docker·容器
大刘讲IT6 小时前
数据治理体系的“三驾马车”:质量、安全与价值挖掘
大数据·运维·经验分享·学习·安全·制造·零售
镰圈量化6 小时前
Django 实现服务器主动给客户端发送消息的几种常见方式及其区别
服务器·django·sqlite
SuperW7 小时前
Linux学习——UDP
linux·学习·udp
szxinmai主板定制专家7 小时前
国产RK3568+FPGA以 ‌“实时控制+高精度采集+灵活扩展”‌ 为核心的解决方案
大数据·运维·网络·人工智能·fpga开发·机器人
xixingzhe27 小时前
docker转移镜像
运维·docker·容器