在討論着四種方法以前,首先要對函數有一個簡單的認識,不管是在形實結合時,仍是在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的內存空間已經被回收。spa
因此不能返回一個自動變量的字符串。。。.net
下面給出四種返回字符串的方法:指針
一、 將字符串指針做爲函數參數傳入,並返回該指針。code
二、 使用malloc函數動態分配內存,注意在主調函數中釋放。blog
三、 返回一個靜態局部變量。內存
四、 使用全局變量。字符串
下面是詳細解釋:get
方法一:將字符串指針做爲函數參數傳入,並返回該指針。
典型的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 g_s; }
參考了:http://blog.csdn.net/turkeyzhou/article/details/6104135#comments
就寫到這裏啦,但願對你有所幫助。。有錯誤的地方還請指正,謝謝~~