C語言動態(tài)內存分配的詳解
C語言動態(tài)內存分配的詳解
1.為什么使用動態(tài)內存分配
數組在使用的時候可能造成內存浪費,使用動態(tài)內存分配可以解決這個問題。
2. malloc和free
C函數庫提供了兩個函數,malloc和free,分別用于執(zhí)行動態(tài)內存分配和釋放。
(1)void *malloc(size_t size);
malloc的參數就是需要分配的內存字節(jié)數。malloc分配一塊連續(xù)的內存。如果操作系統(tǒng)無法向malloc提供更多的內存,malloc就返回一個NULL指針。
(2)void free(void *pointer);
free的參數要么是NULL,要么是一個先前從malloc、calloc或realloc返回的值。
3. calloc和realloc
(1)void *calloc(size_t num_elements,size_t element_size);
calloc也用于內存分配。malloc和calloc之間的主要區(qū)別是后者在返回指向內存的指針之前把它初始化為0。
(2)realloc(void *ptr,size_t new_size);
realloc函數用于修改一個原先已經分配的內存塊的大小。如果它用于擴大一個內存,那么這塊內存原先的內容依然保留,新增加的內存添加到原先內存塊的后面。如果它用于縮小一個內存塊,該內存塊尾部的部分內存被拿掉,剩余部分內存的原先內容依然保留。
4. 使用動態(tài)分配的內存
(1)使用示例
int *pi; pi = malloc(25 * sizeof(int)); if(pi == NULL){ printf("out of memery\n"); exit(1); }
(2)使用間接訪問
int *pi2,i; pi2 = pi; for(i = 0;i < 25;i += 1) *pi2++ = 0;
也可以使用下標。
int i; for(i = 0;i < 25;i += 1) *pi[i] = 0;
5. 常見的動態(tài)內存錯誤
常見的錯誤有:對NULL指針進行解引用操作、對分配的內存進行操作時越過邊界、釋放并非內存分配的內存、試圖釋放一塊動態(tài)分配的內存的一部分以及一塊動態(tài)內存釋放之后被繼續(xù)使用。
以上就是對C語言中動態(tài)內存分配的資料講解,如有疑問請大家留言或者到本站社區(qū)討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
C語言入門篇--四大常量(字面,const修飾,宏,枚舉)及標識符
本篇文章是c語言基礎篇,主要講述一下常量,常量即不可被直接修改的量(const修飾的常變量可間接修改,后續(xù)文章會繼續(xù)說明)請大家持續(xù)關注腳本之家2021-08-08