在Linux中的c程序的典型内存分布中,之前提到的有 text段、data段、bss段、堆和栈这几部分,在笔记“麦子学院c语言->典型c语言程序的c内存分布”中介绍了。但是其实一个c语言进程的内存分布中不止是有这些区域,还有命令行参数、环境变量以及共享库和mmap映射区等区域。如下图所示
------------------------------
环境变量区域
命令行参数
栈
共享库和mmap映射区
堆
bss段
data段
text段
-------------------------------
=====================================================
通常环境变量是通过 name=value 的形式给出的,使用 environ 指针打印出的所有的环境变量的形式就是如此。使用 getenv 函数可以通过给出 name 来获得 value 的值。
函数原型:
函数参数:
- name:想要获取的环境变量名
返回值:
- 调用成功返回指向 value 的指针
- 调用失败返回 NULL
=====================================================
putenv 函数用来向环境表中 添加或者修改 环境变量。
函数原型:
函数参数:
- string:指向环境变量的指针,其中环境变量必须以 "name=value" 的形式给出
返回值:
- 调用成功返回 0
- 调用失败时返回 非0 值
如果环境表中没有 name 这个环境变量,则添加该环境变量;如果环境表中已经有了name这个环境变量,则先删除之前的 value,再修改为新的 value。
=====================================================
setenv 函数和putenv 函数功能类似,可以用来 添加或修改 环境变量。
函数原型:
函数参数:
- name:环境变量名
- value:环境变量值
- overwrite:重写选项,当 name 在环境表中存在时,如果 overwrite 的值为 0 ,则不修改name的值;如果 overwrite 的值为 非0,则修改name的值。
返回值:
- 调用成功返回 0
- 调用失败时返回 非0
=====================================================
putenv 函数和 setenv 函数虽然功能类似,但是这两个函数在实现方面还是有区别的,区别如下:
putenv函数:
- putenv 函数会将参数 string 直接填写到环境表中,不会再为 "name=value" 这个字符串再去分配内存。如果是在一个函数中定义的string,那么在调用该函数后,string 指向的内容可能会被释放,就找不到name环境变量的值了。
setenv 函数:
- setenv 函数和 putenv 函数不同,它会将name和value指向的内容复制一份并为其分配内存,形成 "name=value" 的字符串,并将其地址写入到环境表中。所以就不会出现上面putenv 的情况,就算函数返回了,name 和 value指向的内容被释放了,仍然有一份拷贝在。