我想在UNIX上通過串聯str1和str2來使用putenv()。 我想在環境中添加一個變量或修改一個變量,所以我打電話給putenv()(或者我可以同樣地調用setenv())。在UNIX上使用putenv()時出現問題()
基本上,我收到了str1和str2,我創建了str1 = str2並將它作爲參數傳遞給putenv()。
我顯示的代碼有效,但是當我取消註釋free()調用時,它不會:該變量不會被添加/修改爲環境。
size_t size = strlen(str1) + strlen(str2) + 2; // 2 is for the '\0' and the '='
char *tmp = (char *) malloc(sizeof(char) * size);
char *p;
int pos = 0;
// Copy first word
p = str1;
while (*p != NULL) {
tmp[pos++] = *p++;
}
// Add the '='
tmp[pos++] = '=';
// Copy second word
p = str2;
while (*p != NULL) {
tmp[pos++] = *p++;
}
// Add null character
tmp[pos] = '\0';
int ret = putenv(tmp);
if (ret != 0) {
perror("putenv failed");
}
//free(tmp); // This line is the problem when not commented
我爲代碼冗餘道歉,我知道兩個while循環是相同的。我的問題是,如果我取消註釋免費聲明,然後調用「env」打印環境,則putenv不會添加該值。
我不確定這是爲什麼。現在讓它工作,我有一個內存泄漏,我不喜歡。當我使用數組而不是指針時,它會產生與免註釋相同的問題。
任何想法?
現貨 - 您必須放棄內存,並且如果您隨後更改環境變量的值,則容忍泄漏。基本上,如果你有'setenv()'可用,不要使用'putenv()'。現在是否存在帶有'putenv()'而沒有'setenv()'的系統是有爭議的; 10年前,使用'setenv()'更多的是可移植性責任 - 而'putenv()'是可靠的,但使用起來不會有泄漏的麻煩。 – 2010-09-09 06:41:20
非常感謝您的幫助!我會切換到setenv(),非常感謝。 – Jary 2010-09-09 16:23:46