malloc 不能返回动态内存
關于malloc的理解:
#include <stdio.h> #include <stdlib.h> void getmemory(char *p) {p=(char *) malloc(100);strcpy(p,"hello world"); } int main( ) {char *str=NULL;getmemory(str);printf("%s/n",str);free(str);return 0; }程序崩潰,getmemory中的malloc 不能返回動態內存, free()對str操作很危險。
當參數是指針時容易忽略,請不要用值傳遞(這樣會導致str沒有指向分配到的內存),C語言里沒有引用的話就用指針傳。
C語言是值傳遞,故在函數調用中修改的值,并不會返傳至主調函數。所以原程序在getmemory函數中malloc獲得的地址空間的首地址的值只在函數內部有效,函數調用結束后該值就丟失了
傳值是把實參的值拷貝給形參,運算中是對形參進行操作,實參的值在運算中不會發生變化
傳址是把實參的地址傳給形參,運算中是對實參進行操作,會改變實參的值
此段代碼有錯,getmemory(str)中參數問題。編譯器會為每個函數的參數都復制一份臨時副本,指針參數 p 的副本在C中是_p,并且對_p賦值為p ,即 _p = p 。如果在getmemory函數體內修改了 _p 所指向的內容,則導致參數 p 所指向的內容做相應的修改,這就是指針可用作輸出參數的原因。但此處中getmemory 函數的 _p 申請了新內存,此時 _p 所指的內存地址改變了,但是 p 沒變。所以每次調用getmemory都會造成內存泄露。形參p的域只在函數里有效,p一開始指向你想要的地址,但是當你重新分配內存的時候p指向了新的地址,當你返回函數的時候原來的地址還是空的。要在函數里返回內存有兩種辦法,一種是指針的指針 **p ,用這個指針指向一個需要分配內存的值。另外一種方法更簡單,你在函數里創造一個指針然后 return他就可以了。
正確寫法:
#include <stdio.h> #include <stdlib.h> void getmemory(char **p) { *p=(char *) malloc(100); strcpy(*p,"hello world"); } int main() { char *str=NULL; getmemory(&str); printf("%s/n",str); free(str); return 0; } void getmemory(char &*p) { p=(char *) malloc(100); strcpy(p,"hello world"); }或者
void getmemory(char **p) { *p=(char *)malloc(100); strcpy(*p,"hello world"); }你那樣做開始str和p指向的一樣是NULL(即內容一樣),但是p=(char *) malloc(100); 后str仍然是NULL,但str得到了新的內存~
總結
以上是生活随笔為你收集整理的malloc 不能返回动态内存的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 大数据之Hadoop教程
- 下一篇: STM32----SysTick实现监控