环境变量:用export指令查看
进程所在的环境也有环境变量,进程环境表:当前进程存在一个表,这个表装的就是环境变量的值,
每一个进程都有一份所有环境变量构成的表格,这个表格就是进程环境表,当前进程中可以直接使用这些变量environ
进程环境表其实是一个字符数组,用一个二重指针,用environ指向它,这个指针是操作系统全局的,所以我们使用的时候直接声明就可以了,链接的时候自动会找到他
#include<stdio.h>
int main(void)
{
extern char **environ;
int i = 0;
while(NULL != environ[i])
{
printf("%s\n",environ[i]);
i++;
}
return 0;
}
我们写的程序中,可以直接使用系统中的环境变量,一旦用到系统的环境变量,环境变量是和程序有关的,
我们在应用程序中如何获取指定的环境变量的值,getenv来实现
#include<stdio.h>
#include <stdlib.h>
int main(void)
{
#if 0
extern char **environ;
int i = 0;
while(NULL != environ[i])
{
printf("%s\n",environ[i]);
i++;
}
#endif
printf("PATH = %s\n", getenv("PATH"));
return 0;
}
进程运行的虚拟地址空间
1。操作系统中的每一个进程都在一个独立的地址空间中运行,这些进程彼此间是独立的,互相都不知道
2。操作系统给每个进程逻辑上分配了4G的地址空间,当前进程认为1G是OS 剩下都是我的,其实是分时复用的,虚拟内存映射一部分到物理内存,只有用到的时候才会映射
虚拟(内存)地址到物理(内存)地址的映射
3.这么设计的意义进程隔离,安全性高,为了多个进程同时运行,我们不知道实际运行的物理地址,虚拟地址映射,虚拟地址解决链接时候怎么处理虚拟地址和物理地址,所以应用程序都是从0地址开始的,操作系统解决映射的问题,我们平时应用都在0地址写内存,编译时候不提供链接脚本,因为默认的链接脚本链接到0地址了,OS负责映射,高级操作系统
RTOS都在物理地址运行,任务都是在物理地址运行,所以是高级操作系统
能动态装软件就是这个原因能在系统运行时安装软件就是因为OS可以虚拟地址映射。