C語言中函數(shù)返回字符串的方法匯總
在討論著四種方法之前,首先要對函數(shù)有一個簡單的認(rèn)識,無論是在形實(shí)結(jié)合時,還是在return語句返回時,都有一個拷貝的過程。你傳進(jìn)來的參數(shù)是個值,自然函數(shù)在工作之前要把這個值拷貝一份供自己使用,你傳進(jìn)來的是個地址,函數(shù)也就會拷貝該地址供自己使用。同樣return返回時,如果返回一個值,函數(shù)會將該值拷貝一份以提供給主調(diào)函數(shù)使用,返回的是一個指針(也就是地址),自然拷貝的就是一個地址,供主調(diào)函數(shù)使用。
先給出一個錯誤的例子:
#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; }
編譯一下代碼,會發(fā)現(xiàn)提示一個警告,大概意思就是說返回了一個局部變量的地址。這個程序的輸出結(jié)果是不確定的,因?yàn)槲覀兌贾?,局部變量的生存期是就在塊內(nèi)部,這里也就是在函數(shù)retstring()的內(nèi)部,在main函數(shù)中,name的內(nèi)存空間已經(jīng)被回收。
所以不能返回一個自動變量的字符串。。。
下面給出四種返回字符串的方法:
1、 將字符串指針作為函數(shù)參數(shù)傳入,并返回該指針。
2、 使用malloc函數(shù)動態(tài)分配內(nèi)存,注意在主調(diào)函數(shù)中釋放。
3、 返回一個靜態(tài)局部變量。
4、 使用全局變量。
下面是詳細(xì)解釋:
方法一:將字符串指針作為函數(shù)參數(shù)傳入,并返回該指針。
典型的strcpy()函數(shù)應(yīng)該就是采用的這種方法,第一個參數(shù)為指向目的字符串的指針,返回值也為這個指針。
char* strcpy(char* des,const char* source) { char* r=des; assert((des != NULL) && (source != NULL)); while((*r++ = *source++)!='\0'); return des; }
方法二:使用malloc函數(shù)動態(tài)分配,但是一定要注意在主調(diào)函數(shù)中將其釋放,應(yīng)為malloc動態(tài)分配的內(nèi)存位于堆區(qū),而堆區(qū)的內(nèi)存是要程序員自己釋放的。
一個例子如下:
#include <stdio.h> #include <string.h> #include <stdlib.h> char * retstring(); int main() { char * name2; name2 = retstring(); printf("%s\n",name2); //記住一定要用free釋放,否則會造成內(nèi)存泄露 free(name2); return 0; } char * retstring() { char * name; name = (char *)malloc(10); strcpy(name,"張漢青"); return name; }
方法三:返回一個靜態(tài)局部變量。
一個例子如下:
#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; }
這種方法有一個問題: 由于采用了靜態(tài)局部變量(位于靜態(tài)區(qū),程序結(jié)束時由系統(tǒng)進(jìn)行釋放),這就導(dǎo)致,如果多次調(diào)用這個函數(shù),下一次調(diào)用會將上一次調(diào)用的結(jié)果覆蓋掉。
C語言中的庫函數(shù),tmpnam()函數(shù)、getenv()函數(shù)等應(yīng)該都是采用的這種方法,這也就是為什么,使用這樣的函數(shù)的時候應(yīng)該立即將返回結(jié)果拷貝一份的原因。
方法四: 使用全局變量。
一個例子如下:
char g_s[100]; char* fun() { strcpy(g_s, "abc "); return s; }
就寫到這里啦,希望對你有所幫助。。有錯誤的地方還請指正,謝謝~~
相關(guān)文章
C++實(shí)現(xiàn)LeetCode(152.求最大子數(shù)組乘積)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(152.求最大子數(shù)組乘積),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C語言運(yùn)算符的優(yōu)先級和結(jié)合性實(shí)例詳解
本文主要介紹C語言運(yùn)算符的知識,這里對運(yùn)算符的優(yōu)先級和結(jié)合性做出了詳解,并附實(shí)例代碼,希望能幫助有需要的小伙伴2016-07-07C語言中隱藏結(jié)構(gòu)體的細(xì)節(jié)
以筆者粗淺的認(rèn)識,有兩種最常用的方法,可以實(shí)現(xiàn)庫內(nèi)結(jié)構(gòu)體定義的隱藏:接口函數(shù)形參使用結(jié)構(gòu)體指針,接口函數(shù)形參使用句柄。2017-05-05c++中拷貝構(gòu)造函數(shù)的參數(shù)類型必須是引用
如果拷貝構(gòu)造函數(shù)中的參數(shù)不是一個引用,即形如CClass(const CClass c_class),那么就相當(dāng)于采用了傳值的方式(pass-by-value),而傳值的方式會調(diào)用該類的拷貝構(gòu)造函數(shù),從而造成無窮遞歸地調(diào)用拷貝構(gòu)造函數(shù)。因此拷貝構(gòu)造函數(shù)的參數(shù)必須是一個引用2013-07-07詳解C++模擬實(shí)現(xiàn)priority_queue(仿函數(shù))
本文主要介紹了關(guān)于C++中優(yōu)先級隊(duì)列的模擬實(shí)現(xiàn),以及仿函數(shù)的使用,優(yōu)先級隊(duì)列是一種容器適配器,其第一個元素總是最大的,仿函數(shù)本質(zhì)是一個類,重載了operator(),可改變比較邏輯,同時,文中還介紹了如何進(jìn)行類的比較,如日期類或其指針的比較,以及庫中sort函數(shù)的使用方法2024-10-10