關於函式返回值是指標的問題

2021-07-02 07:09:03 字數 1891 閱讀 8041

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的過載,遇到這種情況,...