2010-11-07 23:43
608人閱讀收藏
舉報string
delete
儲存編譯器
null語言
先看乙個例子,初學者經常碰到的問題
[cpp]view plain
copy
char
*getstring(
void
)
void
main(
void
)
函式getstring中定義的變數p屬於local,當函式結束時自動消失,所以在返回時,根本就得不到p所指的內容。解決辦法有以上常見的幾種
(1)可以使用全域性陣列,使用全域性變數時,在程式結束時才釋放。
(2)在函式getstring()中使用new在堆上動態分配記憶體來建立陣列。c語言中可以使用malloc()函式,不過不要忘記,使用完成後要進行記憶體釋放,不然會造成記憶體洩漏。分別使用delete,free釋放,使用delete時,會呼叫類的析構函式,而free則不會。
[c-sharp]view plain
copy
char
*getstring()
void
main()
(3)可以定義為靜態型別,static char p[ ]="hello world".
用static宣告乙個指標可以,但也不太好,因為如果你多次呼叫這個函式返回多個指標,但這幾個指標實際上指向同一塊位址,改變任何乙個的內容將改變所有指標的內容,這樣也不是很多情況所需要的。
[c-sharp]view plain
copy
char
* getstring(
void
)
(4)用string型別,用string 實現,是值拷貝!不存在釋放記憶體會影響拷貝的問題。
[c-sharp]view plain
copy
string
getstring(
void
)
void
test4(
void
)
(5)使用字串常量,因為字串常量儲存再靜態儲存區域,所以一直都存在,p是臨時變數,但過程結束並不
會釋放這個字串常量.而p就不一樣了,它是乙個陣列,陣列裡面存放了字串,這個字串沒有放在字元
串常量儲存再靜態儲存區域,p是臨時變數,跳出函式之後一般保留一步就釋放了,陣列的空間**了,字串
沒有了。
[c-sharp]view plain
copy
const
char
*getstring(
void
)
char
*getstring(
void
)
void
getstring(
char
* p)
void
test4(
void
)
一般在函式中定義乙個物件有兩種方法:
1、在棧上建立區域性變數。注意,在棧上時!棧用於函式是為了返回時找得到呼叫點(在呼叫時壓入棧的)
,那麼,返回時要pop才能得到。函式體中建立的任何東西都消失了(返回值除外),你返回的指標指向的內
容現在不知被用作什麼用途了,如果你還要修改的話,那麼後果不能確定。
2、在堆中分配。返回時不會摧毀,因為堆是全域性存在的。但函式的呼叫者要記得delete回來的指標。
關於函式返回值是指標的問題
先看乙個例子,初學者經常碰到的問題 函式getstring中定義的變數p屬於local,當函式結束時自動消失,所以在返回時,根本就得不到p所指的內容。解決辦法有以上常見的幾種 1 可以使用全域性陣列,使用全域性變數時,在程式結束時才釋放。2 在函式getstring 中使用new在堆上動態分配記憶體...
返回值是函式指標的函式示例
來自interview的乙個考題,所以寫了乙個測試程式來demonstrate一下。func是乙個函式指標,該函式返回值是int,沒有輸入引數 然後主程式中宣告了乙個函式指標myfuncpointer,該函式指標代表的函 數輸入引數是乙個int,返回值也是乙個函式指標,型別就是func型別的。所以我...
字元指標函式的返回值問題
字元指標函式的返回值問題 今天學弟問了這麼一道問題,為什麼指標型別的函式返回值不是指標而是一串字元,一開始我也很好奇為什麼?後來看了一下原題,發現這個函式是乙個字元指標函式,返回值是乙個字串,這就說得通了。字元指標的返回值是指標 位址 但是字串的名字就是位址,然後又因為cout的過載,遇到這種情況,...