1. getenv:取得環境變量內容
頭文件- #include<stdlib.h>
格式: char * getenv(const char *name);
意義: getenv()用來取得參數name環境變量的內容。
@param name為環境變量的名稱,如果該變量存在則會返回指向該內容的指針。環境變量的格式為name=value。
return 執行成功則返回指向該內容的指針,找不到符合的環境變量名稱則返回NULL。
【注】:相關函數 putenv,setenv,unsetenv;
示例
#include <stdlib.h> mian() { char *p; if((p = getenv(“USER”))) printf(“USER=%s\n”,p); }
執行后顯示: USER = root
2. putenv:改變或增加環境變量
int putenv(const char * string);
意義:putenv()用來改變或增加環境變量的內容。
@param: string的格式為name=value,如果該環境變量原先存在,則變量內容會依參數string改變,否則此參數內容會成為新的環境變量。
reutrn 執行成功則返回0,有錯誤發生則返回-1。
錯誤代碼:ENOMEM 內存不足,無法配置新的環境變量空間。
示例:
#include<stdlib.h> main() { char *p; if((p = getenv(“USER”))) printf(“USER =%s\n”,p); putenv(“USER=test”); printf(“USER=%s\n”,getenv(“USER”)); }
執行 USER=root USER=test
3. setenv:改變或增加環境變量
int setenv(const char *name,const char * value,int overwrite);
name為環境變量名稱字符串。
value則為變量內容。
overwrite用來決定是否要改變已存在的環境變量。如果overwrite不為0,則改變環境變量原有內容,原有內容會被改為參數value所指的變量內容。如果overwrite為0,且該環境變量已有內容,則參數value會被忽略。
reuturn 執行成功則返回0,有錯誤發生時返回-1。
錯誤代碼 ENOMEM 內存不足,無法配置新的環境變量空間
示例
#include<stdlib.h> main() { char * p; if((p=getenv(“USER”))) printf(“USER =%s\n”,p); setenv(“USER”,”test”,1); printf(“USER=%s\n”,getenv(“USEr”)); unsetenv(“USER”); printf(“USER=%s\n”,getenv(“USER”)); }
結果:
USER = root USER = test USER = (null)