您好,登錄后才能下訂單哦!
在討論著四種方法之前,首先要對函數有一個簡單的認識,無論是在形實結合時,還是在return語句返回時,都有一個拷貝的過程。你傳進來的參數是個值,自然函數在工作之前要把這個值拷貝一份供自己使用,你傳進來的是個地址,函數也就會拷貝該地址供自己使用。同樣return返回時,如果返回一個值,函數會將該值拷貝一份以提供給主調函數使用,返回的是一個指針(也就是地址),自然拷貝的就是一個地址,供主調函數使用。
先給出一個錯誤的例子:
#include <stdio.h> #include <string.h> char * retstring(); int main() { char * name2; name2 = retstring(); printf("%s\n",name2); return 0; } char * retstring() { char name[10]; strcpy(name,"漢青"); return name; }
編譯一下代碼,會發現提示一個警告,大概意思就是說返回了一個局部變量的地址。這個程序的輸出結果是不確定的,因為我們都知道,局部變量的生存期是就在塊內部,這里也就是在函數retstring()的內部,在main函數中,name的內存空間已經被回收。
所以不能返回一個自動變量的字符串。。。
下面給出四種返回字符串的方法:
1、 將字符串指針作為函數參數傳入,并返回該指針。
2、 使用malloc函數動態分配內存,注意在主調函數中釋放。
3、 返回一個靜態局部變量。
4、 使用全局變量。
下面是詳細解釋:
方法一:將字符串指針作為函數參數傳入,并返回該指針。
典型的strcpy()函數應該就是采用的這種方法,第一個參數為指向目的字符串的指針,返回值也為這個指針。
char* strcpy(char* des,const char* source) { char* r=des; assert((des != NULL) && (source != NULL)); while((*r++ = *source++)!='\0'); return des; }
方法二:使用malloc函數動態分配,但是一定要注意在主調函數中將其釋放,應為malloc動態分配的內存位于堆區,而堆區的內存是要程序員自己釋放的。
一個例子如下:
#include <stdio.h> #include <string.h> #include <stdlib.h> char * retstring(); int main() { char * name2; name2 = retstring(); printf("%s\n",name2); //記住一定要用free釋放,否則會造成內存泄露 free(name2); return 0; } char * retstring() { char * name; name = (char *)malloc(10); strcpy(name,"張漢青"); return name; }
方法三:返回一個靜態局部變量。
一個例子如下:
#include <stdio.h> #include <string.h> #include <stdlib.h> char * retstring(); int main() { char * name2; name2 = retstring(); printf("%s\n",name2); return 0; } char * retstring() { static char name[10]; strcpy(name,"張漢青"); return name; }
這種方法有一個問題: 由于采用了靜態局部變量(位于靜態區,程序結束時由系統進行釋放),這就導致,如果多次調用這個函數,下一次調用會將上一次調用的結果覆蓋掉。
C語言中的庫函數,tmpnam()函數、getenv()函數等應該都是采用的這種方法,這也就是為什么,使用這樣的函數的時候應該立即將返回結果拷貝一份的原因。
方法四: 使用全局變量。
一個例子如下:
char g_s[100]; char* fun() { strcpy(g_s, "abc "); return s; }
就寫到這里啦,希望對你有所幫助。。有錯誤的地方還請指正,謝謝~~
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。