new 是動態(tài)分配(在堆上分配),你向系統(tǒng)要了 50 B 的內存,如
創(chuàng)新互聯公司于2013年成立,是專業(yè)互聯網技術服務公司,擁有項目做網站、成都做網站網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元義安做網站,已為上家服務,為義安各地企業(yè)和個人服務,聯系電話:028-86922220
char* str=new char[50]; // 50 * 1B
堆上分配就是這情況,你不釋放(delete一下),它就認為你在用著;不會再給別人用
如果給你的你不用了,或是你把它給忘記了,那就算是內存泄露了、
當然,你程序退出的時候,系統(tǒng)會替你回收、不過這樣的習慣不好,你想,如果你寫了死循環(huán)(操作系統(tǒng)、服務器程序等)、那里面不斷滴在內存泄露,你就危險了、后來發(fā)現,不知不覺,內存怎么就不夠用了,明明自己用的不多啊、、
修改一下:
char* fanhui()
{
static char str[100]; // 局部變量,靜態(tài)局部變量,它在第一次調用的時候分配,
cin str; // 函數返回了,str的空間還是存在的,也就是不會重復申請、
return str; // 而且,函數外面通過,指針也是可以訪問他們的、、
}
而
char* fanhui()
{
char str[100]; // 局部變量,默認動態(tài)局部變量,它在每一次調用的時候分配,
cin str; // 函數返回了,str的空間也就不存在了,他是在,棧,上分配的、
return str; // 函數外面通過,指針想訪問?、非法?。?!人都不在了,你喊他干嘛啊??
}
C語言返回字符串有四種方式:1。使用堆空間,返回申請的堆地址,注意釋放2。函數參數傳遞指針,返回該指針3。返回函數內定義的靜態(tài)變量(共享)4。返回全局變量使用分配的內存,地址是有效 \x0d\x0achar *fun() \x0d\x0a{ \x0d\x0achar* s = (char*)calloc(100, sizeof(char*) ); \x0d\x0aif (s) \x0d\x0astrcpy ( s , "abc " ); \x0d\x0areturn s; \x0d\x0a} \x0d\x0a但這種方式需要注意,必須由使用將將返回的地址free掉 \x0d\x0a\x0d\x0a將地址由入參傳入 \x0d\x0achar* fun(char*s) \x0d\x0a{ \x0d\x0aif (s) \x0d\x0astrcpy(s, "abc "); \x0d\x0areturn s; \x0d\x0a} \x0d\x0a這種方式調用都要注意給s分配的大小是足夠。 \x0d\x0a可以這樣: \x0d\x0achar* fun(char*s, int len) \x0d\x0a{ \x0d\x0aif (s) \x0d\x0a{ \x0d\x0astrncpy(s, "abc ", len-1); \x0d\x0as[len-1] = 0; \x0d\x0a} \x0d\x0areturn s; \x0d\x0a} \x0d\x0a\x0d\x0a或才使用局部靜態(tài)變量 \x0d\x0achar* fun() \x0d\x0a{ \x0d\x0astatic char s[100]; \x0d\x0astrcpy(s, "abc "); \x0d\x0areturn s; \x0d\x0a} \x0d\x0a這種方式需要注意,不要修改返回的這個字符串,由于是共享地址,對它的修改會反應到每個調用者的。可以這樣: \x0d\x0aconst char* fun() \x0d\x0a{ \x0d\x0astatic char s[100]; \x0d\x0astrcpy(s, "abc "); \x0d\x0areturn s; \x0d\x0a} \x0d\x0a\x0d\x0a還有一種是使用全局變量 \x0d\x0achar g_s[100]; \x0d\x0achar* fun() \x0d\x0a{ \x0d\x0astrcpy(g_s, "abc "); \x0d\x0areturn s; \x0d\x0a} \x0d\x0a同樣的,也要注意這個變量可存儲的最大空間。
別聽 樓上 的 瞎說, 也 別 百度 了, 都是 錯 的, 我 告訴 你 正確 答案
函數 中 的 字符 串 在 函數 結束 的 時候 會 自動 被 釋放 掉, 所以 即使 返回 char* 指向 的
也 就是 原 函數 字符串 的 地址, 訪問 的 是 一個 系統(tǒng) 沒有 分配 給 程序 的 內存, 雖然 編譯器 不會 報錯, 但 語法 絕對 是 錯誤 的,而且 你 不一定 能 得到 一個 正確 的 結果
三種 解決 方法:
1, struct ret { char a[100]; }; 返回 一個 結構, 結構里面 包含 字符串
2, char* ret = (char *)malloc(100 * sizeof (char)); 在 函數 里 開 一個 動態(tài) 的 字符串, 這個 可以 返回, 不過 動態(tài) 內存 需要 手動 free 掉
3, 這個 不是 c語言 了, 調用 c++ 里面 的 string 類型, 也是 最簡單 的 辦法, 省心, 安全
要返回字符串 需要返回char*類型
需要注意的是 返回的字符串 不能是該函數的局部變量,否則會導致出錯
可以是參數字符串,全局變量,靜態(tài)局部變量,或者動態(tài)分配的內存
比如
char?*my_str_cpy(char?*d,?char?*s)
{
char?*p=d;
while(*p++=*s++);
return?d;//返回參數字符串。?
}
文章題目:c語言字符串返回函數 c語言如何返回字符串
本文路徑:http://chinadenli.net/article2/doggoic.html
成都網站建設公司_創(chuàng)新互聯,為您提供網站排名、電子商務、微信公眾號、做網站、移動網站建設、網站策劃
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯