傳統數組的長度必須事先制定好,且只能是常整數,不能是變量,長度一旦定義便不能再改變;其占用的內存我們無法手動釋放,在一個函數運行間該函數眾的數組所分配到的空間知道函數運行完之后才會被釋放;其不能夠跨函數運行.
所以就出現了動態數組.動態數組很好的解決了傳統數組的這幾個缺陷.
舉個例子:
int *p=(int *)malloc(int size);
上面這個語句分配了兩片內存,一片內存是動態分配的總共size個字節,另一片是靜態的.
malloc函數只有一個int類型的形參,表示的是分配的字節數,malloc函數的作用就是請求size個字節的內存空間,若成功便返回空間的地址,若失敗就會返回null.malloc函數能且只能返回一個第一個字節的地址,故我們需要把這個無任何實際意義的第一個字節的地址轉化為一個有實際意義的地址,比如:
int *p=(int *)malloc(100);
表示將非配好的100個字節的第一個字節地址轉化為int *類型的地址,這樣p就指向了第一個的四個字節,p+1就指向了第二個四個字節...以此類推.
動態數組釋放內存
freep(p)表示吧p所指向的內存給釋放掉,而p自身的內存是靜態的我們不能手動釋放,p本身的內存只能在p變量鎖在的函數運行結束是系統自行釋放.
靜動態內存的比較:
靜態內存有系統自動分配,且由系統釋放;
靜態內存是棧分配的
動態內存是由開發者手動分配,手動釋放的;
動態內存是堆分配的
咨詢熱線
010-85377344
135-21581588
微信客服
QQ客服
3026106565 點擊咨詢