使用getenv函数可跨平台获取环境变量,需包含<cstdlib>头文件,返回const char*类型,若变量不存在则返回nullptr,示例中通过判断空指针并封装为std::string提高安全性,不同系统环境变量名有差异需注意兼容性。

在C++中获取系统环境变量,主要依赖标准库函数 getenv,它是 C 标准库的一部分,在 <cstdlib> 头文件中声明。这个方法跨平台(Windows、Linux、macOS)都可用,使用简单。
使用 getenv 获取环境变量
getenv 函数根据环境变量名返回对应的值。如果变量不存在,返回 nullptr。
- 包含头文件:
#include <cstdlib> - 调用方式:
std::getenv("变量名") - 返回值为 const char*,表示字符串内容
示例代码:
#include <iostream>
#include <cstdlib>
<p>int main() {
const char* path = std::getenv("PATH");
if (path != nullptr) {
std::cout << "PATH: " << path << std::endl;
} else {
std::cout << "PATH 环境变量未找到" << std::endl;
}</p><pre class='brush:php;toolbar:false;'>const char* home = std::getenv("HOME"); // Linux/macOS
if (home != nullptr) {
std::cout << "HOME: " << home << std::endl;
}
const char* user = std::getenv("USERNAME"); // Windows
if (user != nullptr) {
std::cout << "USERNAME: " << user << std::endl;
}
return 0;}
立即学习“C++免费学习笔记(深入)”;
安全地转换为 std::string
由于 getenv 返回的是 const char*,直接使用可能空指针崩溃。建议封装判断并转为 string 避免问题。
#include <string>
<p>std::string getEnvVar(const std::string& key) {
const char* value = std::getenv(key.c_str());
return value ? std::string(value) : "";
}</p>这样调用更安全:
std::string path = getEnvVar("PATH");
if (!path.empty()) {
std::cout << "PATH = " << path << std::endl;
}
跨平台注意事项
不同系统的环境变量名称不同:
- Linux/macOS 常用:
HOME、USER、SHELL - Windows 常用:
USERPROFILE、USERNAME、TEMP - 通用变量:
PATH、LANG、TEMP
编写跨平台程序时,注意判断操作系统并选择合适变量名。
基本上就这些。getenv 简单直接,适合绝大多数场景。不复杂但容易忽略空指针检查。











